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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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Scope 



The scope for this technical specification is to specify the security features and mechanisms for secure access to the IM 
subsystem (IMS) for the 3G mobile telecommunication system. 

Since the scope also encompasses the use of these security features and mechanisms for secure access to IMS in the 
context of fixed broadband networks, Annex L specifies how the material in the main body and other normative 
Annexes of this document apply to the fixed broadband networks. 

The IMS in UMTS will support IP Multimedia applications such as video, audio and multimedia conferences. 3GPP has 
chosen SIP, Session Initiation Protocol, as the signalling protocol for creating and terminating Multimedia sessions, 
cf RFC 3261 [6]. This specification only deals with how the SIP signalling is protected between the subscriber and the 
IMS, how the subscriber is authenticated and how the subscriber authenticates the IMS. 
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3 Definitions, symbols and abbreviations 

3.1 Definitions 

For the purposes of the present document, the following terms and definitions apply. 

Authenticated (re-) registration: A registration i.e. a SIP register is sent towards the Home Network which will trigger 
a authentication of the IMS subscriber i.e. a challenge is generated and sent to the UE. 

Confidentiality: The property that information is not made available or disclosed to unauthorised individuals, entities 
or processes. 

Data integrity: The property that data has not been altered in an unauthorised manner. 

Data origin authentication: The corroboration that the source of data received is as claimed. 

Entity authentication: The provision of assurance of the claimed identity of an entity. 

Key freshness: A key is fresh if it can be guaranteed to be new, as opposed to an old key being reused through actions 
of either an adversary or authorised party. 
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ISIM - EM Subscriber Identity Module: For the purposes of this document the ISIM is a term that indicates the 
collection of IMS security data and functions on a UICC. The ISIM may be a distinct application on the UICC. 



3.3 



Abbreviations 



For the purposes of the present document, the following abbreviations apply, TS 21.905 [7] contains additional 
applicable abbreviations: 



AAA 

AKA 

CSCF 

HSS 

IBCF 

IM 

IMPI 

IMPU 

IMS 

ISIM 

MAC 

ME 

NAPT 

NAT 

SA 

SEG 

SDP 

SIP 

UA 



Authentication Authorisation Accounting 

Authentication and key agreement 

Call Session Control Function 

Home Subscriber Server 

Interconnection Border Control Function 

IP Multimedia 

IM Private Identity 

IM Public Identity 

IP Multimedia Core Network Subsystem 

IM Services Identity Module 

Message Authentication Code 

Mobile Equipment 

Network Address and Port Translation 

Network Address Translation 

Security Association 

Security Gateway 

Session Description Protocol 

Session Initiation Protocol 

User Agent 



Overview of the security architecture 



In the PS domain, the service is not provided until a security association is established between the UE and the network. 
IMS is essentially an overlay to the PS-Domain and has a low dependency of the PS-domain. Consequently a separate 
security association is required between the multimedia client and the IMS before access is granted to multimedia 
services. The IMS Security Architecture is shown in the following figure. 

IMS authentication keys and functions at the user side shall be stored on a UICC. It shall be possible for the IMS 
authentication keys and functions to be logically independent to the keys and functions used for PS domain 
authentication. However, this does not preclude common authentication keys and functions from being used for IMS 
and PS domain authentication according to the guidelines given in clause 8. 

For the purposes of this document the ISIM is a term that indicates the collection of IMS security data and functions on 
a UICC. Further information on the ISIM is given in clause 8. 
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Figure 1 : The IMS security architecture 

There are five different security associations and different needs for security protection for IMS and they are numbered 
1,2, 3, 4 and 5 in figure 1 where: 

1. Provides mutual authentication. The HSS delegates the performance of subscriber authentication to the S-CSCF. 
However the HSS is responsible for generating keys and challenges. The long-term key in the ISlM and the HSS 
is associated with the IMPl. The subscriber will have one (network internal) user private identity (IMPI) and at 
least one external user public identity (IMPU). 

2. Provides a secure link and a security association between the UE and a P-CSCF for protection of the Gm 
reference point. Data origin authentication is provided i.e. the corroboration that the source of data received is as 
claimed. For the definition of the Gm reference point cf TS 23.002 [9]. 

3. Provides security within the network domain internally for the Cx-interface. This security association is covered 
by TS 33.210 [5]. For the definition of the Cx-interface cf TS 23.002 [9]. 

4. Provides security between different networks for SIP capable nodes. This security association is covered by 
TS 33.210 [5]. This security association is only applicable when the P-CSCF resides in the VN and if the 
P-CSCF resides in the HN then bullet point number five below applies, cf also figure 2 and figure 3. 

5. Provides security within the network internally between SIP capable nodes. This security association is covered 
by TS 33.210 [5]. Note that this security association also applies when the P-CSCF resides in the HN. 

There exist other interfaces and reference points in IMS, which have not been addressed above. Those interfaces and 
reference points reside within the IMS, either within the same security domain or between different security domains. 
The protection of all such interfaces and reference points apart from the Gm reference point are protected as specified in 
TS 33.210 [5]. 

Mutual authentication is required between the UE and the HN. 

The mechanisms specified in this technical specification are independent of the mechanisms defined for the CS- and 
PS-domain. 

An independent IMS security mechanism provides additional protection against security breaches. For example, if the 
PS-Domain security is breached the IMS would continue to be protected by it's own security mechanism. As indicated 
in figure 1 the P-CSCF may be located either in the Visited or the Home Network. The P-CSCF shall be co-located 
within the same network as the GGSN, which may reside in the VPLMN or HPLMN according to the APN and GGSN 
selection criteria, cf TS 23.060 [10]. 
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Figure 2: This figure gives an overview of the security architecture for IIVIS and the relation with 
Network Domain security, cf. TS 33.210 [5], when the P-CSCF resides in the VN 
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Figure 3: This figure gives an overview of the security architecture for IMS and the relation with 
Network Domain security, cf. TS 33.210 [5], when the P-CSCF resides in the HN 

The confidentiality and integrity protection for SIP-signalling is provided in a hop-by-hop fashion, cf figure 2 and 
figure 3. The first hop i.e. between the UE and the P-CSCF is specified in this technical specification. The other hops, 
inter-domain and intra-domain are specified in TS 33.210 [5]. 
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5 Security features 

5.1 Secure access to IMS 

5.1 .1 Authentication of tine subscriber and tine network 

Authentication between the subscriber and the network shall be performed as specified in clause 6.1. 

An IM-subscriber will have its subscriber profile located in the HSS in the Home Network. The subscriber profile will 
contain information on the subscriber that may not be revealed to an external partner, cf TS 23.228 [3]. At registration 
an S-CSCF is assigned to the subscriber by the I-CSCF. The subscriber profile will be downloaded to the S-CSCF over 
the Cx-reference point from the HSS (Cx-Pull). When a subscriber requests access to the IP Multimedia Core Network 
Subsystem this S-CSCF will check, by matching the request with the subscriber profile, if the subscriber is allowed to 
continue with the request or not i.e. Home Control (Authorization of IM-services). 

All SIP-signalling will take place over the PS-domain in the user plane i.e. IP Multimedia Core Network Subsystem is 
essentially an overlay to the PS-domain. Hence the Visited Network will have control of all the subscribers in the PS- 
domain i.e. Visited Control (Authorization of bearer resources) since the Visited Network provides the subscriber with a 
transport service and its associated QoS. 

For IM-services a new security association is required between the UE and the IMS before access is granted to IM- 
services. 

The mechanism for mutual authentication in UMTS is called UMTS AKA. It is a challenge response protocol and the 
AuC in the Home Stratum derives the challenge. A Quintet containing the challenge is sent from the Home Stratum to 
the Serving Network. The Quintet contains the expected response XRES and also a message authentication code MAC. 
The Serving Network compares the response from the UE with the XRES and if they match the UE has been 
authenticated. The UE calculates an expected MAC, XMAC, and compares this with the received MAC and if they 
match the UE has authenticated the Serving Network. 

The AKA-protocol is a secure protocol developed for UMTS and the same concept/principles will be reused for the IP 
Multimedia Core Network Subsystem, where it is called IMS AKA. 

NOTE: Although the method of calculating the parameters in UTMS AKA and IMS AKA are identical, the 
parameters are transported in slightly different ways. In UMTS, the UE's response RES is sent in the 
clear, while in IMS RES is not sent in the clear but combined with other parameters to form an 
authentication response and the authentication response is sent to the network (as described in 

RFC 3310 [17]). 

The Home Network authenticates the subscriber at anytime via the registration or re-registration procedures. 

5.1 .2 Re-Autinentication of tine subscriber 

Initial registration shall always be authenticated. It is the policy of the operator that decides when to trigger a re- 
authentication by the S-CSCF. Hence a re-registration might not need to be authenticated. 

A SIP REGISTER message, which has not been integrity protected at the first hop, shall be considered as initial 
registration. 

The S-CSCF shall also be able to initiate an authenticated re-registration of a user at any time, independent of previous 
registrations. 

5.1 .3 Confidentiality protection 

Possibility for IMS specific confidentiality protection shall be provided to SIP signalling messages between the UE and 
the P-CSCF. Operators shall take care that the deployed confidentiality protection solution and roaming agreements 
fulfils the confidentiality requirements presented in the local privacy legislation. The following mechanisms are 
provided at SIP layer: 

1. The UE shall always offer encryption algorithms for P-CSCF to be used for the session, as specified in clause 7. 
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2. The P-CSCF shall decide whether the IMS specific encryption mechanism is used. If used, the UE and the 
P-CSCF shall agree on security associations, which include the encryption key that shall be used for the 
confidentiality protection. The mechanism is based on IMS AKA and specified in clause 6.1. 

Confidentiality between CSCFs, and between CSCFs and the HSS shall rely on mechanisms specified by Network 
Domain Security in TS 33.210 [5]. 

5.1 .4 Integrity protection 

Integrity protection shall be applied between the UE and the P-CSCF for protecting the SIP signalling, as specified in 
clause 6.3. The following mechanisms are provided. 

1. The UE and the P-CSCF shall negotiate the integrity algorithm that shall be used for the session, as specified in 
clause 7. 

2. The UE and the P-CSCF shall agree on security associations, which include the integrity keys, that shall be used 
for the integrity protection. The mechanism is based on IMS AKA and specified in clause 6. 1 . 

3. The UE and the P-CSCF shall both verify that the data received originates from a node, which has the agreed 
integrity key. This verification is also used to detect if the data has been tampered with. 

4. Replay attacks and reflection attacks shall be mitigated. 

Integrity protection between CSCFs and between CSCFs and the HSS shall rely on mechanisms specified by Network 
Domain Security in TS 33.210 [5]. 

NOTE 1: TLS is mandatorily supported by SIP proxies according to RFC 3261 [6], and operators may use it to 
provide confidentiality and integrity inside their networks instead of or on top of IPsec, as the intra- 
domain Za interface is optional, and TLS may also be used between IMS networks on top of IPsec. It 
should be pointed out, that the 3GPP specifications do not provide support for TLS certificate 
management in a fashion similar to TS 33.310 (NDS/AF) [24] nor do they ensure backward compatibility 
with Release 5 CSCFs nor interoperability with other networks which do not use TLS, in case TLS is 
used by Release 6 CSCFs. These management and capability issues need then to be solved by manual 
configuration of the involved operators. 



5.2 Network topology hiding 



The operational details of an operator's network are sensitive business information that operators are reluctant to share 
with their competitors. While there may be situations (partnerships or other business relations) where the sharing of 
such information is appropriate, the possibility should exist for an operator to determine whether or not the internals of 
its network need to be hidden. 

It shall be possible to hide the network topology from other operators, which includes the hiding of the number of 
S-CSCFs, the capabilities of the S-CSCFs and the capability of the network. 

The I-CSCF/IBCF shall have the capability to encrypt the addresses of all the entities of the operator network in SIP 
Via, Record-Route, Route and Path headers and then decrypt the addresses when handling the response to a request. 
The P-CSCF may receive routing information that is encrypted but the P-CSCF will not have the key to decrypt this 
information. 

The mechanism shall support the scenario that different I-CSCFs/IBCF s in the HN may encrypt and decrypt the 
addresses of all the entities of the operator network. 

5.3 SIP Privacy handling in IMS Networks 

Privacy may in many instances be equivalent with confidentiality i.e. to hide the information (using encryption and 
encryption keys) from all entities except those who are authorized to understand the information. The SIP Privacy 
Extensions for IMS Networks do not provide such confidentiality. The purpose of the mechanism is rather to give an 
IMS subscriber the possibility to withhold certain identity information of the subscriber as specified in 
IETF RFC 3323 [29] and IETF RFC 3325 [30]. 



£75/ 



3GPP TS 33.203 version 7.3.0 Release 7 1 4 ETSI TS 1 33 203 V7.3.0 (2006-09) 

NOTE 1 : It is useful that the privacy mechanism for IMS networks does not create states in the CSCFs other than 
the normal SIP states. 

5.4 SIP Privacy handling when interworking with non-IMS 
Networks 

When a Rel-6 IMS is interworking with a non-IMS network, the CSCF in the IMS network shall decide the trust 
relation with the other end. The other end is trusted when the security mechanism for the interworking (see clause 6.5) 
is applied as well as the availability of an inter- working agreement. If the interworking non-IMS network is not trusted, 
the privacy information shall be removed from the traffic towards to this non-IMS network. When receiving SIP 
signalling, the CSCF shall also verify if any privacy information is already contained. If the interworking non-IMS 
network is not trusted, the information shall be removed by the CSCF, and retained otherwise. 

Because absence of the security mechanism for the interworking (see clause 6.5) indicates an untrusted non-IMS 

network, separate CSCFs are usually needed to interface with IMS and non-IMS networks. The CSCF interfacing with 

IMS networks implicitly trusts all IMS networks reachable via the SEG that establishes security according to 

TS 33.210 [5]. A Rel-5 CSCF always assumes this trust relationship and network configuration. For a Rel-6 CSCF, this 

implicit trust setting shall be a configuration option, that an operator can set according to his network and interface 

configuration. 



6 Security mechanisms 

6.1 Authentication and key agreement 

The scheme for authentication and key agreement in the IMS is called IMS AKA. The IMS AKA achieves mutual 
authentication between the ISIM and the HN, cf figure 1. The identity used for authenticating a subscriber is the private 
identity, IMPI, which has the form of a NAI, cf. TS 23.228 [3]. The HSS and the ISIM share a long-term key associated 
with the IMPI. 

The HN shall choose the IMS AKA scheme for authenticating an IM subscriber accessing through UMTS. The security 
parameters e.g. keys generated by the IMS AKA scheme are transported by SIP. 

The generation of the authentication vector AV that includes RAND, XRES, CK, IK and AUTN shall be done in the 
same way as specified in TS 33.102 [1]. The ISIM and the HSS keep track of counters SQNjsim and SQNhss 
respectively. The requirements on the handling of the counters and mechanisms for sequence number management are 
specified in TS 33.102 [1]. The AMF field can be used in the same way as in TS 33.102 [1]. 

Furthermore two pairs of (unilateral) security associations (SAs) are established between the UE and the P-CSCF. The 
subscriber may have several IMPUs associated with one IMPI. These may belong to the same or different service 
profiles. Only two pairs of SAs shall be active between the UE and the P-CSCF. These two pairs of SAs shall be 
updated when a new successful authentication of the subscriber has occurred, cf clause 7.4. 

It is the policy of the HN that decides if an authentication shall take place for the registration of different IMPUs e.g. 
belonging to same or different service profiles. Regarding the definition of service profiles cf. TS 23.228 [3]. 

6.1 .1 Authentication of an IM-subscriber 

Before a user can get access to the IM services at least one IMPU needs to be registered and the IMPI authenticated in 
the IMS at application level. In order to get registered the UE sends a SIP REGISTER message towards the SIP 
registrar server i.e. the S-CSCF, cf figure 1, which will perform the authentication of the user. The message flows are 
the same regardless of whether the user has an IMPU already registered or not. 
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UE P-CSCF 

(SMI) Register 



I-CSCF 



HSS 



S-CSCF 



(SM2) Register 




(CM2) AV-Req-Resp 
(SM4) 4xx AuthChallenge 



(SMS) 4xx Auth_Challenge 
(SM6) 4xx AuthChallenge 




(SM12)2xxAuth_Ok 



(SMIO) 2xx AuthOk 
(SMll) 2xx Auth_Ok ^ 



<C Cx-Put ^^^ 



Figure 4: The IMS Authentication and Key Agreement for an unregistered IM subscriber and 
successful mutual authentication with no synchronization error 

The detailed requirements and complete registration flows are defined in TS 24.229 [8] and TS 24.228 [11]. 

SMn stands for SIP Message n and CMm stands for Cx message m which has a relation to the authentication process: 

SM1: 
REGISTER(IMPI, IMPU) 

In SM2 and SM3 the P-CSCF and the I-CSCF respectively forwards the SIP REGISTER towards the S-CSCF. 

After receiving SM3, if the IMPU is not currently registered at the S-CSCF, the S-CSCF needs to set the registration 
flag at the HSS to initial registration pending. This is done in order to handle UE terminated calls while the initial 
registration is in progress and not successfully completed. The registration flag is stored in the HSS together with the 
S-CSCF name and user identity, and is used to indicate whether a particular IMPU of the user is unregistered or 
registered at a particular S-CSCF or if the initial registration at a particular S-CSCF is pending. The registration flag is 
set by the S-CSCF sending a Cx-Put to the HSS. If the IMPU is currently registered, the S-CSCF shall leave the 
registration flag set to registered. At this stage the HSS has performed a check that the IMPI and the IMPU belong to 
the same user. 

Upon receiving the SIP REGISTER the S-CSCF CSCF shall use an Authentication Vector (AV) for authenticating and 
agreeing a key with the user. If the S-CSCF has no valid AV then the S-CSCF shall send a request for AV(s) to the HSS 
in CMl together with the number m of AVs wanted where m is at least one. 

CM1: 
Cx-AV-Req(IMPI, m) 



Upon receipt of a request from the S-CSCF, the HSS sends an ordered array of n authentication vectors to the S-CSCF 
using CM2. The authentication vectors are ordered based on sequence number. Each authentication vector consists of 
the following components: a random number RAND, an expected response XRES, a cipher key CK, an integrity key IK 
and an authentication token AUTN. Each authentication vector is good for one authentication and key agreement 
between the S-CSCF and the IMS user. 
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CM2: 

Cx-AV-Req-Resp(IMPI, RAND1 ||AUTN1 ||XRES1 ||CK1 ||IK1 ,....,RANDn||AUTNn||XRESn||CKn||IKn) 



When the S-CSCF needs to send an authentication challenge to the user, it selects the next authentication vector from 
the ordered array, i.e. authentication vectors in a particular S-CSCF are used on a first-in / first-out basis. 

The S-CSCF sends a SIP 4xx Auth_Challenge i.e. an authentication challenge towards the UE including the challenge 
RAND, the authentication token AUTN in SM4. It also includes the integrity key IK and the cipher key CK for the 
P-CSCF. RFC 3310 [17] specifies how to populate the parameters of an authentication challenge. The S-CSCF also 
stores the RAND sent to the UE for use in case of a synchronization failure. 

The verification of the SQN by the USIM and ISIM will cause the UE to reject an attempt by the S-CSCF to re-use a 
AV. Therefore no AV shall be sent more than once. 

NOTE: This does not preclude the use of the normal SIP transaction layer re-transmission procedures. 

SM4: 

4xx Auth_Challenge{IMPI, RAND, AUTN, IK, CK) 

When the P-CSCF receives SMS it shall store the key(s) and remove that information and forward the rest of the 
message to the UE i.e. 

SM6: 

4xx Auth_Challenge(IMPI, RAND, AUTN) 



Upon receiving the challenge, SM6, the UE takes the AUTN, which includes a MAC and the SQN. The UE calculates 
the XMAC and checks that XMAC=MAC and that the SQN is in the correct range as in TS 33.102 [1]. If both these 
checks are successful the UE uses RES and some other parameters to calculate an authentication response. This 
response is put into the Authorization header and sent back to the registrar in SM7.RFC 3310 [17] specifies how to 
populate the parameters of the response. It should be noted that the UE at this stage also computes the session keys CK 
and IK. 

SM7: 

REGISTER(IMPI, Authentication response) 

The P-CSCF forwards the authentication response in SMS to the I-CSCF, which queries the HSS to find the address of 
the S-CSCF. In SM9 the I-CSCF forwards the authentication response to the S-CSCF. 

Upon receiving SM9 containing the response, the S-CSCF retrieves the active XRES for that user and uses this to check 
the authentication response sent by the UE as described in RFC 3310 [17]. If the check is successful then the user has 
been authenticated and the IMPU is registered in the S-CSCF. If the IMPU was not currently registered, the S-CSCF 
shall send a Cx-Put to update the registration-flag to registered. If the IMPU was currently registered the registration- 
flag is not altered. 

It shall be possible to implicitly register IMPU(s). (see clause 4.3.3.4 in TS 23.228 [3]). All the IMPU(s) being 
implicitly registered shall be delivered by the HSS to the S-CSCF and subsequently to the P-CSCF. The S-CSCF shall 
regard all implicitly registered IMPU(s) as registered IMPU(s). 

When an IMPU has been registered this registration will be valid for some period of time. Both the UE and the S-CSCF 
will keep track on a timer for this purpose but the expiration time in the UE is smaller than the one in the S-CSCF in 
order to make it possible for the UE to be registered and reachable without interruptions. A successful registration of a 
previously registered IMPU (including implicitly registered IMPUs) means the expiry time of the registration is 
refreshed. 

If the user has been successfully authenticated, the S-CSCF sends a SMIO SIP 2xx Auth_OK message to the I-CSCF 
indicating that the registration was successful. In SMI 1 and SMI 2 the I-CSCF and the P-CSCF respectively forward the 
SIP 2xx Auth_OK towards the UE. 
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It should be noted that the UE initiated re-registration opens up a potential denial-of-service attack. That is, an attacker 
could try to register an already registered IMPU and respond with an incorrect authentication response in order to make 
the HN de-register the IMPU. For this reason a subscriber, when registered, shall not be de-registered if it fails an 
authentication. 

The lengths of the IMS AKA parameters are specified in clause 6.3.7 of TS 33.102 [1]. 

6.1 .2 Authentication failures 



6.1.2.1 



User authentication failure 



In this case the authentication of the user should fail at the S-CSCF due an incorrect response (received in SM9). 
However, if the response is incorrect, then the IK used to protect SM7 will normally be incorrect as well, which will 
normally cause the integrity check at the P-CSCF to fail before the response can be verified at S-CSCF. In this case 
SM7 is discarded by the IPsec layer at the P-CSCF. 

If the integrity check passes but the response is incorrect, the message flows are identical up to and including SM9 as a 
successful authentication. Once the S-CSCF detects the user authentication failure it should proceed in the same way as 
having received SM9 in a network authentication failure (see clause 6.1.2.2). 



6.1.2.2 



Network authentication failure 



In this clause the case when the authentication of the network is not successful is specified. When the check of the 
MAC in the UE fails the network can not be authenticated and hence registration fails. The flow is identical as for the 
successful registration in 6.1.1 up to SM6. 



UE 



P-CSCF 



I-CSCF 



HSS 



S-CSCF 



Authentl cation 
Failure 



(SM7) Register 



(SMS) Register 



Cx-Query 



(SM9) Register 



(CM3) Put 
(CM4) Put-Resp 



(SM12) 4xx AuthFailure . 



(SMIO) 4xx AuthFailure 
(SMll) 4xx Auth_Failure ^ 



Figure 5 

The UE shall send a Register message towards the HN including an indication of the cause of failure in SM7. The 
P-CSCF and the I-CSCF forward this message to the S-CSCF. 

SM7: 

REGISTER(Failure = AuthenticationFailure, IMPI) 
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Upon receiving SM9, which includes the cause of authentication failure, the S-CSCF shall set the registration-flag in the 
HSS Xounregistered or Not registered, if the IMPU is not currently registered. To set the flag the S-CSCF sends in CM3 
a Cx-Put to the HSS. If the IMPU is currently registered, the S-CSCF does not update the registration flag. 

CMS: 

Cx-AV-Put(IMPI, Clear S-CSCF name) 



The HSS responds to CM3 with a Cx-Put-Resp in CM4. 

In SMIO the S-CSCF sends a 4xx Auth_Failure towards the UE indicating that authentication has failed, no security 
parameters shall be included in this message. 

SM10: 

SIP/2.0 4xxAuth Failure 



6.1 .2.3 Incomplete authentication 

When the S-CSCF receives a new REGISTER request and challenges this request, it considers any previous 
authentication to have failed. It shall delete any information relating to the previous authentication, although the 
S-CSCF may send a response if the previous challenge is answered. A challenge to the new request proceeds as 
described in clause 6.1.1. 

If the S-CSCF does not receive a response to an authentication challenge within an acceptable time, it considers the 
authentication to have failed. If the IMPU was not already registered, the S-CSCF shall send a Cx-Put to the HSS to set 
the registration-flag for that IMPU to Not registered or unregistered (see message CM3 in clause 6.1.2.2). If the IMPU 
was already registered, the S-CSCF does not change the registration-flag. 



6.1 .3 Synchronization failure 



In this clause the case of an authenticated registration with synchronization failure is described. After re- 
synchronization, authentication may be successfully completed, but it may also happen that in subsequent attempts 
other failure conditions (i.e. user authentication failure, network authentication failure) occur. In below only the case of 
synchronization failure with subsequent successful authentication is shown. The other cases can be derived by 
combination with the flows for the other failure conditions. 
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Figure 6 

The flow equals the flow in 6.1.1 up to SM6. When the UE receives SM6 it detects that the SQN is out of range and 
sends a synchronization failure back to the S-CSCF in SM7. RFC 3310 [17] describes the fields to populate 
corresponding parameters of synchronization failure. 

SM7: 

REGISTER(Failure = Synchronization Failure, AUTS, IMPi; 

Upon receiving the Synchronization Failure and the AUTS the S-CSCF sends an Av-Req to the HSS in CM3 including 
the RAND stored by the S-CSCF and the required number of Avs, m. 

CMS: 

Cx-AV-Req(IMPI, RAND,AUTS, m) 



The HSS checks the AUTS as in clause 6.3.5 of TS 33.102 [1]. After potentially updating the SQN, the HSS sends new 
AVs to the S-CSCF in CM4. 



CM4: 

Cx-AV-Req-Resp(IMPI, n,RANDi||AUTNi||XRESi||CKi||IKi,....,RANDn||AUTN„||XRESn||CKn||IKn) 



When the S-CSCF receives the new batch of authentication vectors from the HSS it deletes the old ones for that user in 
the S-CSCF. 

The rest of the messages i.e. SM10-SM18 including the Cx messages are exactly the same as SM4-SM12 and the 
corresponding Cx messages in 6.1.1. 

6.1 .4 Network Initiated autinentications 

In order to authenticate an already registered user, the S-CSCF shall send a request to the UE to initiate a re-registration 
procedure. When received at the S-CSCF, the re-registration shall trigger a new IMS AKA procedure that will allow the 
S-CSCF to re-authenticate the user. 
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Figure 7 

The UE shall initiate the re-registration on the reception of the Authentication Required indication. In the event that the 
UE does not initiate the re-registration procedure after the request from the S-CSCF, the S-CSCF may decide to de- 
register the subscriber or re-issue an Authentication-Required. 

6.1 .5 Integrity protection indicator 

In order to decide whether a REGISTER request from the UE needs to be authenticated, the S-CSCF needs to know 
about the integrity protection applied to the message. The P-CSCF attaches an indication to the REGISTER request to 
inform the S-CSCF that the message was integrity protected if: 

the P-CSCF receives a REGISTER containing an authentication response and the message is protected with an 
SA created during this authentication procedure; or 

the P-CSCF receives a REGISTER not containing an authentication response and the message is protected with 
an SA created by latest successful authentication (from the P-CSCF perspective). 

For all other REGISTER requests the P-CSCF attaches an indication that the REGISTER request was not integrity 
protected or ensures that there is no indication about integrity protection in the message. 



6.2 Confidentiality mechanisms 



If the local policy in P-CSCF requires the use of IMS specific confidentiality protection mechanism between UE and 
P-CSCF, IPsec ESP as specified in RFC 2406 [13] shall provide confidentiality protection of SIP signalling between the 
UE and the P-CSCF, protecting all SIP signalling messages at the IP level. IPSec ESP general concepts on Security 
Policy management. Security Associations and IP traffic processing as described in reference RFC 2401 [14] shall also 
be considered. ESP confidentiality shall be applied in transport mode between UE and P-CSCF. 

The method to set up ESP security associations (SAs) during the SIP registration procedure is specified in clause 7. As a 
result of an authenticated registration procedure, two pairs of unidirectional SAs between the UE and the P-CSCF all 
shared by TCP and UDP, shall be established in the P-CSCF and later in the UE. One SA pair is for traffic between a 
client port at the UE and a server port at the P-CSCF and the other SA is for traffic between a client port at the P-CSCF 
and a server port at the UE. For a detailed description of the establishment of these security associations see clause 7. 

The encryption key CKesp is the same for the two pairs of simultaneously established SAs. The encryption key CKesp is 
obtained from the key CKim established as a result of the AKA procedure, specified in clause 6.1, using a suitable key 
expansion function. 

The encryption key expansion on the user side is done in the UE. The encryption key expansion on the network side is 
done in the P-CSCF. 
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6.3 Integrity mechanisms 



IPsec ESP as specified in reference RFC 2406 [13] shall provide integrity protection of SIP signalling between the UE 
and the P-CSCF, protecting all SIP signalling messages at the IP level. IPSec ESP general concepts on Security Policy 
management, Security Associations and IP traffic processing as described in reference RFC 2401 [14] shall also be 
considered. ESP integrity shall be applied in transport mode between UE and P-CSCF. 

The method to set up ESP security associations (SAs) during the SIP registration procedure is specified in clause 7. As a 
result of an authenticated registration procedure, two pairs of unidirectional SAs between the UE and the P-CSCF, all 
shared by TCP and UDP, shall be established in the P-CSCF and later in the UE. One SA pair is for traffic between a 
client port at the UE and a server port at the P-CSCF and the other SA is for traffic between a client port at the P-CSCF 
and a server port at the UE. For a detailed description of the establishment of these security associations see clause 7. 

The integrity key IKesp is the same for the two pairs of simultaneously established SAs. The integrity key IKesp is 
obtained from the key IKim established as a result of the AKA procedure, specified in clause 6. 1, using a suitable key 
expansion function. This key expansion function depends on the ESP integrity algorithm and is specified in Annex I of 
this specification. 

The integrity key expansion on the user side is done in the UE. The integrity key expansion on the network side is done 
in the P-CSCF. 

The anti-replay service shall be enabled in the UE and the P-CSCF on all established SAs. 



6.4 Hiding mechanisms 



The Hiding Mechanism is optional for implementation. All I-CSCFs/IBCFs in the HN shall share the same encryption 
and decryption key Kv. If the mechanism is used and the operator policy states that the topology shall be hidden the I- 
CSCF/IBCF shall encrypt the hiding information elements when the I-CSCF/IBCF forwards SIP Request or Response 
messages outside the hiding network's domain. The hiding information elements are entries in SIP headers, such as Via, 
Record-Route, Route and Path, which contain addresses of SIP proxies in hiding network. When I-CSCF/IBCF 
receives a SIP Request or Response message from outside the hiding network's domain, the I-CSCF/IBCF shall 
decrypt those information elements that were encrypted by I-CSCF/IBCF in this hiding network domain. 

The purpose of encryption in network hiding is to protect the identities of the SIP proxies and the topology of the hiding 
network. Therefore, an encryption algorithm in confidentiality mode shall be used. The network hiding mechanism will 
not address the issues of authentication and integrity protection of SIP headers. The AES in CBC mode with 128-bit 
block and 128-bit key shall be used as the encryption algorithm for network hiding. In the CBC mode under a given 
key, if a fixed IV is used to encrypt two same plaintexts, then the ciphertext blocks will also be equal. This is 
undesirable for network hiding. Therefore, random IV shall be used for each encryption. The same IV is required to 
decrypt the information. The IV shall be included in the same SIP header that includes the encrypted information. 

6.5 CSCF interoperating with proxy located in a non-IMS 
network 

SIP signalling protected by TLS specified in RFC 3261 [6] may be used for protecting the SIP interoperation between 
an IMS CSCF with a proxy/CSCF located in a foreign network. The CSCF may request the TLS connection with a 
foreign Proxy by publishing sips: URI in DNS server, that can be resolved via NAPTR/SRV mechanism specified in 
RFC 3263 [23]. When sending/receiving the certificate during the TLS handshaking phase, the CSCF shall verify the 
name on the certificate against the list of the interworking partners. 

The TLS session could be inititiated from either network. A TLS connection is capable of carrying multiple SIP dialogs. 

Applying this method is to prevent attacks on SIP level, but it does not prohibit other security methods to be applied so 
as to strengthen the security for IP based networks. This part is specified in Annex A of TS 33.210 [5]. 

NOTE 1: NOTE 1 in clause 5.1.4 on the use of TLS also applies here. 
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7 Security association set-up procedure 

The security association set-up procedure is necessary in order to decide what security services to apply and when the 
security services start. In the IMS authentication of users is performed during registration as specified in clause 6.1. 
Subsequent signalling communications in this session will be integrity protected based on the keys derived during the 
authentication process. 

7.1 Security association parameters 

For protecting IMS signalling between the UE and the P-CSCF it is necessary to agree on shared keys that are provided 
by IMS AKA, and a set of parameters specific to a protection method. The security mode setup (cf clause 7.2) is used 
to negotiate the SA parameters required for IPsec ESP with authentication and confidentiality, in accordance with the 
provisions in clauses 5.1.3 and 6.2. 

The SA parameters that shall be negotiated between UE and P-CSCF in the security mode set-up procedure are: 

- Encryption algorithm 

The encryption algorithm is either DES-EDE3-CBC as specified in RFC 2451 [20] or AES-CBC as specified in 
RFC 3602 [22] with 128 bit key. 

Both encryption algorithms shall be supported by both, the UE and the P-CSCF. 

- Integrity algorithm 

NOTE: What is called "authentication algorithm" in RFC 2406 [13] is called "integrity algorithm" in this 
specification in order to be in line with the terminology used in other 3GPP specifications and, in 
particular, to avoid confusion with the authentication algorithms used in the AKA protocol. 

The integrity algorithm is either HMAC-MD5-96 [15] or HMAC-SHA-1-96 [16]. 

Both integrity algorithms shall be supported by both, the UE and the P-CSCF as mandated by RFC 2406 [13]. In 
the unlikely event that one of the integrity algorithms is compromised during the lifetime of this specification, 
this algorithm shall no longer be supported. 

NOTE: If only one of the two integrity algorithms is compromised then it suffices for the IMS to remain secure 
that the algorithm is no longer supported by any P-CSCF. The security mode set-up procedure 
(cf. clause 7.2) will then ensure that the other integrity algorithm is selected. 

- SPI (Security Parameter Index) 

The SPI is allocated locally for inbound SAs. The triple (SPI, destination IP address, security protocol) uniquely 
identifies an SA at the IP layer. The UE shall select the SPIs uniquely, and different from any SPIs that might be 
used in any existing SAs (i.e. inbound and outbound SAs). The SPIs selected by the P-CSCF shall be different 
than the SPIs sent by the UE, cf. clause 7.2. In an authenticated registration, the UE and the P-CSCF each select 
two SPIs, not yet associated with existing inbound SAs, for the new inbound security associations at the UE and 
the P-CSCF respectively. 

NOTE: This allocation of SPIs ensures that protected messages in the uplink always differ from protected 
messages in the downlink in, at least, the SPI field. This thwarts reflection attacks. When several 
applications use IPsec on the same physical interface the SIP application should be allocated a separate 
range of SPIs. 

The following SA parameters are not negotiated: 

Life type: the life type is always seconds; 

SA duration: the SA duration has a fixed length of 2^^-l; 

NOTE: The S A duration is a network layer concept. From a practical point of view, the value chosen for "SA 
duration" does not impose any limit on the lifetime of an S A at the network layer. The S A lifetime is 
controlled by the SIP application as specified in clause 7.4. 
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Mode: transport mode; 

Key length: the length of the integrity key IKesp depends on the integrity algorithm. It is 128 bits for 
HMAC-MD5-96 and 160 bits for HMAC-SHA-1-96. 

Key length: the length of the encryption key depends on the encryption algorithm. The entropy of the key shall at 
least be 128 bits. 

Selectors: 

The security associations (SA) have to be bound to specific parameters (selectors) of the SIP flows between UE and 
P-CSCF, i.e. source and destination IP addresses, transport protocols that share the SA, and source and destination 
ports. 

IP addresses are bound to two pairs of SAs, as in clause 6.3, as follows: 

- inbound SA at the P-CSCF: 

The source and destination IP addresses associated with the S A are identical to those in the header of the IP 
packet in which the initial SIP REGISTER message was received by the P-CSCF. 

- outbound SA at the P-CSCF: 

the source IP address bound to the outbound SA equals the destination IP address bound to the inbound SA; 
the destination IP address bound to the outbound SA equals the source IP address bound to the inbound SA. 

NOTE: This implies that the source and destination IP addresses in the header of the IP packet in which the 
protected SIP REGISTER message was received by the P-CSCF need to be the same as those in the 
header of the IP packet in which the initial SIP REGISTER message was received by the P-CSCF. 

The transport protocol selector shall allow UDP and TCP. 

Ports: 

1 . The P-CSCF associates two ports, called port_ps and port_pc, with each pair of security assocations 
established in an authenticated registration. The ports port_ps and port_pc are different from the standard SIP 
ports 5060 and 5061. No unprotected messages shall be sent from or received on the ports port_ps and 
port_pc. From a security point of view, unprotected messages may be received on any port which is different 
from the ports port_ps and port_pc. The number of the ports port_ps and port_pc are communicated to the 
UE during the security mode set-up procedure, cf. clause 7.2. These ports are used with both, UDP and TCP. 
The use of these ports may differ for TCP and UDP, as follows: 

UDP case: the P-CSCF receives requests and responses protected with ESP from any UE on the port 
port_ps (the"protected server port"). The P-CSCF sends requests and responses protected with ESP to a 
UE on the port port_pc (the "protected client port"). 

TCP case: the P-CSCF, if it does not have a TCP connection towards the UE yet, shall set up a TCP 
connection from its port_pc to the port port_us of the UE before sending a request to it.. 

NOTE: Both the UE and the P-CSCF may set up a TCP connection from their client port to the other end's server 
port on demand. An already existing TCP connection may be reused by both the P-CSCF or the UE; but it 
is not mandatory. 

NOTE: The protected server port port_ps stays fixed for a UE until all IMPUs from this UE are de-registered. It 
may be fixed for a particular P-CSCF over all UEs, but there is no need to fix the same protected server 
port for different P-CSCFs. 

NOTE: The distinction between the UDP and the TCP case reflects the different behaviour of SIP over UDP and 
TCP, as specified in section 18 of RFC 3261 [6]. 

2. The UE associates two ports, called port_us and port_uc, with each pair of security assocations established in 
an authenticated registration. The ports port_us and port_uc are different from the standard SIP ports 5060 
and 506 1 . No unprotected messages shall be sent from or received on the ports port_us and port_uc. From a 
security point of view, unprotected messages may be received on any port which is different from the ports 
port_us and port_uc. The number of the ports portjus and port_uc are communicated to the P-CSCF during 
the security mode set-up procedure, cf clause 7.2. These ports are used with both, UDP and TCP. The use of 
these ports may differ for TCP and UDP, as follows: 
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UDP case: the UE receives requests and responses protected with ESP on the pon port_us (the "protected 
server port"). The UE sends requests and responses protected with ESP on the port port_uc (the 
"protected client port"). 

TCP case: the UE, if it does not have a TCP connection towards the P-CSCF yet, shall set up a TCP 
connection to the port port_ps of the P-CSCF before sending a request to it. 

NOTE: Both the UE and the P-CSCF may set up a TCP connection from their client port to the other end's server 
port on demand. An already existing TCP connection may be reused by both the P-CSCF or the UE, but it 
is not mandatory. 

NOTE: The protected server port port_us stays fixed for a UE until all IMPUs from this UE are de-registered. 

NOTE: The distinction between the UDP and the TCP case reflects the different behaviour of SIP over UDP and 
TCP, as specified in section 18 of RFC 3261 [6] 

3. The P-CSCF is allowed to receive only REGISTER messages and error messages on unprotected ports. All 
other messages not arriving on a protected port shall be either discarded or rejected by the P-CSCF. 

4. The UE is allowed to receive only the following messages on an unprotected port: 
- responses to unprotected REGISTER messages; 

error messages. 
All other messages not arriving on a protected port shall be rejected or silently discarded by the UE. 
The following rules apply: 

1 . For each unidirectional S A which has been established and has not expired, the SIP application at the P-CSCF 
stores at least the following data: (UE_IP_address, UE_protected_port, P-CSCF_protected_port, SPI, IMPI, 
IMPUl, ... , IMPUn, lifetime) in an "SA_table". The pair (UE_protected_port, P-CSCF_protected_port) equals 
either {portjuc, port_ps) or (port_us, port_pc). 

NOTE: The SPI is only required when initiating and deleting SAs in the P-CSCF. The SPI is not exchanged 
between IPsec and the SIP layer for incoming or outgoing SIP messages. 

2. The SIP application at the P-CSCF shall check upon receipt of a protected REGISTER message that the source 
IP address in the packet headers coincide with the UE's IP address inserted in the Via header of the protected 
REGISTER message. If the Via header does not explicitly contain the UE's IP address, but rather a symbolic 
name then the P-CSCF shall first resolve the symbolic name by suitable means to obtain an IP address. 

3. The SIP application at the P-CSCF shall check upon receipt of an initial REGISTER message or a re-REGISTER 
message that the pair (UE_IP_address, UE_protected_client_port), where the UE_IP_address is the source IP 
address in the packet header and the protected client port is sent as part of the security mode set-up procedure 
(cf. clause 7.2), has not yet been associated with entries in the "SA_table". Furthermore, the P-CSCF shall check 
that, for any one IMPI, no more than six SAs per direction are stored at any one time. If these checks are 
unsuccessful the registration is aborted and a suitable error message is sent to the UE. 

NOTE: According to clause 7.4 on SA handling, at most six SAs per direction may exist at a P-CSCF for one user 
at any one time. 

4. For each incoming protected message the SIP application at the P-CSCF shall verify that the correct inbound SA 
according to clause 7.4 on SA handling has been used. The SA is identified by the triple (UE_IP_address, 
UE_protected_port, P-CSCF_protected_port) in the "SA_table". The SIP application at the P-CSCF shall further 
ensure that the user associated with the SA, which was used to protect the incoming message from the UE, is 
identical to the user who is associated at SIP level with the message sent by the P-CSCF towards the network. 

NOTE: Not all SIP messages necessarily contain public or private identities, e.g. subsequent messages in a 

dialogue. Other information, e.g. a dialogue identifier, may be used to associate the message with a user 
at SIP level. 

5. For each unidirectional SA which has been established and has not expired, the SIP application at the UE stores 
at least the following data: (UE_protected_port, P-CSCF_protected_port, SPI, lifetime) in an "SA_table". The 
pair (UE_protected_port, P-CSCF_protected_port) equals either (port_uc, ponj)s) or (pon_us, ponj)c). 
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NOTE: The SPI is only required to initiate and delete S As in the UE. The SPI is not exchanged between IPsec 
and the SIP layer for incoming or outgoing SIP messages. 

6. When establishing a new pair of SAs (cf. clause 6.3) the SIP application at the UE shall ensure that the selected 
numbers for the protected ports do not correspond to an entry in the "SA_table". 

NOTE: Regarding the selection of the number of the protected port at the UE it is generally recommended that 

the UE randomly selects the number of the protected port from a sufficiently large set of numbers not yet 
allocated at the UE. This is to thwart a limited form of a Denial of Service attack. UMTS PS access link 
security also helps to thwart this attack. 

7. For each incoming protected message the SIP application at the UE shall verify that the correct inbound SA 
according to clause 7.4 on SA handling has been used. The SA is identified by the pair (UE_protected_port, 
P-CSCF_protected_port) in the "SA table". 

NOTE: If the integrity check of a received packet fails then IPsec will automatically discard the packet. 

7.2 Set-up of security associations (successful case) 

The set-up of security associations is based on RFC 3329 [21]. Annex H of this specification shows how to use 
RFC 3329 [21] for the set-up of security associations. 

In this clause the normal case is specified i.e. when no failures occurs. Note that for simplicity some of the nodes and 
messages have been omitted. Hence there are gaps in the numbering of messages, as the I-CSCF is omitted. 



UE 



P-CSCF 



S-CSCF 



(SMI) Register 



(SM2) Register 



(SM6) 4xx AuthCiiallenge 



^ 



(SM4) 4xx Auth_Challenge 



^ 
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(SMS) Register 
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(SMIO) 2xx Auth_01; 
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Figure 8 

The UE sends a Register message towards the S-CSCF to register the location of the UE and to set-up the security 
mode, cf. clause 6.1. In order to start the security mode set-up procedure, the UE shall include a Security-setup-line in 
this message. 

The Security-setup-line in SMI contains the Security Parameter Index values and the protected ports selected by the 
UE. It also contains a list of identifiers for the integrity and encryption algorithms, which the UE supports. 



SM1: 



REGISTER(Security-setup = SPI_U, Port_U, UE integrity and encryption algorithms list) 
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SPI_U is the symbolic name of a pair of SPI values (cf. clause 7.1) (spi_uc, spi_us) that the UE selects. spi_uc is the 
SPI of the inbound SA at UE's the protected client port, and spi_us is the SPI of the inbound SA at the UE's protected 
server port. The syntax of spi_uc and spi_us are defined in Annex H. 

Port_U is the symbolic name of a pair of port numbers (port_uc, portjus) as defined in clause 7.1. The syntax of 
port_uc and port_us is defined in Annex H. 

Upon receipt of SMI, the P-CSCF temporarily stores the parameters received in the Security-setup-line together with 
the UE's IP address from the source IP address of the IP packet header, the IMPI and IMPU. Upon receipt of SM4, the 
P-CSCF adds the keys IKim and CKim received from the S-CSCF to the temporarily stored parameters. 

The P-CSCF then selects the SPIs for the inbound SAs. The P-CSCF shall define the SPIs such that they are unique and 
different from any SPIs as received in the Security-setup-line from the UE. 

NOTE: This rule is needed since the UE and the P-CSCF use the same key for inbound and outbound traffic. 

In order to determine the integrity and encryption algorithm the P-CSCF proceeds as follows: the P-CSCF has a list of 
integrity and encryption algorithms it supports, ordered by priority. The P-CSCF selects the first algorithm combination 
on its own list which is also supported by the UE. If the UE did not include any confidentiality algorithm in SMI then 
the P-CSCF shall either select the NULL encryption algorithm or abort the procedure, according to its policy on 
confidentiality. 

NOTE: It should be noted that, if the P-CSCF policy requires confidentiality, then all UEs with no encryption 
support would be denied access to the IMS network. This would apply in particular to UEs, which 
support only a Release 5-version of this specification or only Early IMS according to [25]. 

The P-CSCF then establishes two new pairs of SAs in the local security association database. 

The Security-setup-\mt in SM6 contains the SPIs and the ports assigned by the P-CSCF. It also contains a list of 
identifiers for the integrity and encryption algorithms, which the P-CSCF supports. The only exception from this is the 
case that the P-CSCF is configured to never apply confidentiality. In this case, it shall not include encryption algorithms 
to the Security-setup-\mt in SM6. 

NOTE: The P-CSCF may be configured to never apply confidentiality, e.g. because it trusts the encryption 
provided by the underlying access network. If the P-CSCF is configured to apply confidentiality 
whenever the UE supports it then the P-CSCF always includes the encryption algorithms in SM6, which 
it supports, even if the UE did not include encryption algorithms in SML This is to thwart bidding down 
attacks. 



SM6: 



4xx Auth_Challenge(Security-setup = SPI_P, Port_P, P-CSCF integrity and encryption algorittims list) 

SPI_P is the symbolic name of the pair of SPI values (cf. clause 7.1) (spi_pc, spi_ps) that the P-CSCF selects. spi_pc is 
the SPI of the inbound SA at the P-CSCF' s protected client port, and spi_ps is the SPI of the inbound SA at the 
P-CSCF' s protected server port. The syntax of spijic and spi_ps is defined in Annex H. 

Port_P is the symbolic name of the port numbers {port_pc, port_ps) as defined in clause 7.1. The syntax of Port_P is 
defined in Annex H. 

Upon receipt of SM6, the UE determines the integrity and encryption algorithms as follows: the UE selects the first 
integrity and encryption algorithm combination on the list received from the P-CSCF in SM 6 which is also supported 
by the UE. If the P-CSCF did not include any confidentiality algorithm in SM6 then the UE shall select the NULL 
encryption algorithm. 



NOTE: Release 5 UE will not support any encryption algorithms, and will choose the first Release 5 integrity 
algorithm on the list received from the P-CSCF in SM6. 

The UE then proceeds to establish two new pairs of SAs in the local SAD. 

The UE shall integrity and confidentiality protect SM7 and all following SIP messages. Furthermore the integrity and 
encryption algorithms list, SPI_P, and Port_P received in SM6, and SPI_U, Port_U sent in SMI shall be included: 
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SM7: 
REGISTER(Security-setup : 



SPI_U, Port_U, SPI_P, Port_P, P-CSCF integrity and encryption algorithms list) 



After receiving SM7 from the UE, the P-CSCF shall check whether the integrity and encryption algorithms list, SPI_P 
and Port_P received in SM7 is identical with thecorresponding parameters sent in SM6. It further checks whether 
SPI_U and Porf_C/ received in SM7 are identical with those received in SMI. If these checks are not successful the 
registration procedure is aborted. The P-CSCF shall include in SMS information to the S-CSCF that the received 
message from the UE was integrity protected as indicated in clause 6.1.5. The P-CSCF shall add this information to all 
subsequent REGISTER messages received from the UE that have successfully passed the integrity check in the 
P-CSCF. 



SMS: 



REGISTER(lntegrity-Protection = Successful, IMPi; 

The P-CSCF finally sends SM12 to the UE. SM12 does not contain information specific to security mode setup (i.e. a 
Security-setup line), but with sending SM12 not indicating an error the P-CSCF confirms that security mode setup has 
been successful. After receiving SM12 not indicating an error, the UE can assume the successful completion of the 
security-mode setup. 

An example of how to make use of two pairs of unidirectional SAs is illustrated in the figure below with a set of 
example message exchanges protected by the respective IPsec SAs where the INVITE and following messages are 
assumed to be carried over TCP. 
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Figure 9 



7.3 Error cases in the set-up of security associations 
7.3.1 Error cases related to IIVIS AKA 

Errors related to IMS AKA failures are specified in clause 6. 1 . However, this clause additionally describes how these 
shall be treated, related to security setup. 



7.3.1.1 



User authentication failure 



In this case, SM7 fails integrity check by IPsec at the P-CSCF if the IKm derived from RAND at UE is wrong. The SIP 
application at the P-CSCF never receives SM7. It shall delete the temporarily stored SA parameters associated with this 
registration after a time-out. 
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In case IKjm was derived correctly, but the response was wrong the authentication of the user fails at the S-CSCF due to 
an incorrect response. The S-CSCF shall send a 4xx Auth_Failure message to the UE, via the P-CSCF, which may pass 
through an already established SA. Afterwards, both, the UE and the P-CSCF shall delete the new SAs. 

7.3.1 .2 Network authentication failure 

If the UE is not able to successfully authenticate the network, the UE shall send a REGISTER message which may pass 
through an already established SA, indicating a network authentication failure, to the P-CSCF. The P-CSCF deletes the 
new SAs after receiving this message. 

7.3.1 .3 Synchronisation failure 

In this situation, the UE observes that the AUTN sent by the network in SM6 contains an out-of-range sequence 
number. The UE shall send a REGISTER message to the P-CSCF, which may pass through an already established SA, 
indicating the synchronization failure. The P-CSCF deletes the new SAs after receiving this message. 

7.3.1 .4 Incomplete authentication 

If the UE responds to an authentication challenge from a S-CSCF, but does not receive a reply before the request times 
out, the UE shall start a registration procedure if it still requires any IM services. The first message in this registration 
should be protected with an SA created by a previous successful authentication if one exists. 

When the P-CSCF receives a challenge from the S-CSCF and creates the corresponding SAs during a registration 
procedure, it shall delete any information relating to any previous registration procedure (including the SAs created 
during the previous registration procedure). 

If the P-CSCF deletes a registration SA due to its lifetime being exceeded, the P-CSCF should delete any information 
relating to the registration procedure that created the SA. 

7.3.2 Error cases related to the Security-Set-up 

7.3.2.1 Proposal unacceptable to P-CSCF 

In this case the P-CSCF cannot accept the proposal set sent by the UE in the Security-Set-up command of SMI. The 
P-CSCF shall respond to SMI indicating a failure, by sending an error response to the UE. 

7.3.2.2 Proposal unacceptable to UE 

If the P-CSCF sends in the security-setup line of SM6 a proposal that is not acceptable for the UE, the UE shall abandon 
the registration procedure. 

7.3.2.3 Failed consistency check of Security-Set-up lines at the P-CSCF 

The P-CSCF shall check whether authentication and encryption algorithms list received in SM7 is identical with the 
authentication and encryption algorithms list sent in SM6. If this is not the case the registration procedure is aborted. 
(Cf clause 7.2). 



7.4 Authenticated re-registration 



Every registration that includes a user authentication attempt produces new security associations. If the authentication is 
successful, then these new security associations shall replace the previous ones. This clause describes how the UE and 
P-CSCF handle this replacement and which SAs to apply to which message. 

When security associations are changed in an authenticated re-registration then the protected server ports at the UE 
(port_us) and the P-CSCF (port_ps) shall remain unchanged, while the protected client ports at the UE (port_uc) and 
the P-CSCF {port_pc) shall change. For the definition of these ports see clause 7.1. 

If the UE has an already active pair of security associations, then it shall use this to protect the REGISTER message. If 
the S-CSCF is notified by the P-CSCF that the REGISTER message from the UE was integrity-protected it may decide 
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not to authenticate the user by means of the AKA protocol. However, the UE may send unprotected REGISTER 
messages at any time. In this case, the S-CSCF shall authenticate the user by means of the AKA protocol. In particular, 
if the UE considers the SAs no longer active at the P-CSCF, e.g., after receiving no response to several protected 
messages, then the UE should send an unprotected REGISTER message. 

Security associations may be unidirectional or bi-directional. This clause assumes that security associations are 
unidirectional, as this is the general case. For IP layer SAs, the lifetime mentioned in the following clauses is the 
lifetime held at the application layer. Furthermore deleting an S A means deleting the SA from both the application and 
IPsec layer. The message numbers, e.g. SMI, used in the following clauses relate to the message flow given in 
clause 6.1.1. 

7.4.1 Void 

7.4.1 a Management of security associations in tine UE 

The UE shall be involved in only one registration procedure at a time, i.e. the UE shall remove any data relating to any 
previous incomplete registrations or authentications, including any SAs created by an incomplete authentication. 

The UE may start a registration procedure with two existing pairs of SAs. These will be referred to as the old SAs. The 
authentication produces two pairs of new SAs. These new SAs shall not be used to protect non-authentication traffic 
until noted during the authentication flow. In the same way, certain messages in the authentication shall be protected 
with a particular SA. If the UE receives a message protected with the incorrect SA, it shall discard the message. 

A successful authentication proceeds in the following steps: 

- The UE sends the SMI message to register with the IMS. If SMI was protected, it shall be protected with the old 
outbound SA. 

The UE receives an authentication challenge in a message (SM6) from the P-CSCF. This message shall be 
protected with the old inbound SA if SMI was protected and unprotected otherwise. 

If this message SM6 can be successfully processed by the UE, the UE creates the new SAs, which are derived 
according to clause 7.1. The lifetime of the new SAs shall be set to allow enough time to complete the 
registration procedure. The UE then sends its response (SM7) to the P-CSCF, which shall be protected with the 
new outbound SA. Meanwhile, if SMI was protected, the UE shall use the old SAs for messages other than those 
in the authentication, until a successful message of new authentication is received (SM12); if SMI was 
unprotected, the UE is not allowed to use IMS service until it receives an authentication successful message 
(SM12). 

The UE receives an authentication successful message (SM12) from the P-CSCF. It shall be protected with the 
new inbound SA. 

After the successful processing of this message by the UE, the registration is complete. The UE sets the lifetime 
of the new SAs such that it either equals the latest lifetime of the old SAs or it will expire shortly after the 
registration timer in the message, depending which gives the SAs the longer life. For further SIP messages sent 
from UE, the new outbound SAs are used, with the following exception: when a SIP message is part of a 
pending SIP transaction it may still be sent over the old S A. A SIP transaction is called pending if it was started 
using an old SA. When a further SIP message protected with a new inbound SA is successfully received from the 
P-CSCF, then the old SAs shall be deleted as soon as either all pending SIP transactions have been completed, or 
have timed out. The old SAs shall be always deleted when the Ufetime is expired. This completes the SA 
handling procedure for the UE. 

A failure in the authentication can occur for several reasons. If the SMI was not protected, then no protection shall be 
applied to the failure messages, except the user authentication failure message which shall be protected with the new 
SA. If SMI was protected, the old SAs shall be used to protect the failure messages. In both cases, after processing the 
failure message, the UE shall delete the new SAs. 

The UE shall monitor the expiry time of registrations without an authentication and if necessary increase the lifetime of 
the SAs created by the last successful authentication such that it will expire shortly after the registration timer in the 
message. 

NOTE: In particular this means that the lifetime of a SA is never decreased. 
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The UE shall delete any SA whose lifetime is exceeded. The UE shall delete all SAs it holds once all the IMPUs are de- 
registered. 

7.4.2 Void 

7.4.2a Management of security associations in tine P-CSCF 

When the S-CSCF initiates an authentication by sending a challenge to the UE, the P-CSCF may already contain 
existing SAs from previously completed authentications. It may also contain two existing pairs of SAs from an 
incomplete authentication. These will be referred to as the old and registration SAs respectively. The authentication 
produces two pairs of new SAs. These new SAs shall not be used to protect non-authentication traffic until noted during 
the authentication flow. Similarly certain messages in the authentication shall be protected with a particular SA. If the 
P-CSCF receives a message protected with the incorrect SA, it shall discard the message. 

The P-CSCF associates the IMPI given in the registration procedure and all the successfully registered IMPUs related to 
that IMPI to an SA. 

A successful authentication proceeds in the following steps: 

The P-CSCF receives the SMI message. If SMI is protected, it shall be protected with the old inbound SA. 

The P-CSCF forwards the message containing the challenge (SM6) to the UE. This shall be protected with the 
old outbound SA, if SMI was protected and unprotected otherwise. 

The P-CSCF then creates the new SAs, which are derived according to clause 7. 1 . The expiry time of the new 
SAs shall be set to allow enough time to complete the registration procedure. The registration SAs shall be 
deleted if they exist. 

The P-CSCF receives the message carrying the response (SM7) from the UE. It shall be protected using the new 
inbound SA. If SMI was protected, the old SAs are used to protect messages other than those in the 
authentication. 

The P-CSCF forwards the successful registration message (SMI 2) to the UE. It shall be protected using the new 
outbound SA. This completes the registration procedure for the P-CSCF. The P-CSCF sets the expiry time of the 
new SAs such that they either equals the latest lifetime of the old SAs or it will expire shortly after the 
registration timer in the message, depending which gives the SAs the longer life. 

After SM12 is sent, the P-CSCF handles the UE related SAs according to following rules: 

If there are old SAs, but SMI belonging to the same registration procedure was received unprotected, the 
P-CSCF considers error cases happened, and assumes UE does not have those old SAs for use. In this case 
the P-CSCF shall remove the old SAs. 

If SMI belonging to the same registration procedure was protected with an old valid SA, the P-CSCF keeps 
this inbound SA and the corresponding three SAs created during the same registration with the UE active, 
and continues to use them. Any other old SAs are deleted. When the old SAs have only a short time left 
before expiring or a further SIP message protected with a new inbound SA is successfully received from the 
UE, the P-CSCF starts to use the new SAs for outbound messages with the following exception: when a SIP 
message is part of a pending SIP transaction it may still be sent over the old S A. A SIP transaction is called 
pending if it was started using an old S A. The old SAs are then deleted as soon as all pending SIP 
transactions have been completed, or have timed out. The old SAs are always deleted when the old SAs 
lifetime are expired. When the old SAs expire without a further SIP message protected by the new SAs, the 
new SAs are taken into use for outbound messages. This completes the SA handling procedure for the 
P-CSCF. 

A failure in the authentication can occur for several reasons. If the SMI was not protected, then no protection shall be 
applied to the failure messages, except the user authentication failure message which shall be protected with the new 
SAs. If SMI was protected, the old SAs shall be used to protect the failure messages. In both cases, after processing the 
failure message, the P-CSCF shall delete the new SAs. 

The P-CSCF shall monitor the expiry time of registrations without an authentication and if necessary increase the 
lifetime of SAs created by the last successful authentication such that it will expire shortly after the registration timer in 
the message. 
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The P-CSCF shall delete any SA whose lifetime is exceeded. The P-CSCF shall delete all SAs it holds that are 
associated with a particular IMPI once all the associated IMPUs are de-registered. 

7.5 Rules for security association handling when the UE 
changes IP address 

When a UE changes its IP address, e.g. by using the method described in RFC 3041 [18], then the UE shall delete the 
existing SA's and initiate an unprotected registration procedure using the new IP address as the source IP address in the 
packets carrying the REGISTER messages. 

8 ISIM 

For the purposes of this document the ISIM is a term that indicates the collection of IMS security data and functions on 
a UICC. The following implementation options are permitted: 

Use of a distinct ISIM application on a UICC which does not share security functions with the USIM; 

Use of a distinct ISIM application on a UICC which does share security functions with the USIM; 

- Use of a USIM apphcation on a UICC. 

NOTE: For later releases other implementations of ISIM are foreseen to be permitted. 

If there is an ISIM and a USIM application on a UICC, then the ISIM application shall always be used for IMS 
authentication. 

There shall only be one ISIM for each IMPI. The IMS subscriber shall not be able to modify or enter the IMPI. The 
IMS subscriber shall not be able to modify or enter the Home Domain Name. 

8.1 Requirements on the ISIM application 

This clause identifies requirements on the ISIM application to support IMS access security. It does not identify any data 
or functions that may be required on the ISIM application for non-security purposes. 

The ISIM shall include: 

- The IMPI; 

- At least one IMPU; 

Home Network Domain Name; 

Support for sequence number checking in the context of the IMS Domain; 

The same framework for algorithms as specified for the USIM applies for the ISIM; 

An authentication Key. 

The ISIM shall deliver the CK to the UE although it is not required that SIP signalling is confidentiality protected. 

At UE power off the existing SAs in the MT shall be deleted. The session keys and related information in the S A shall 
never be stored on the ISIM. 

8.2 Sharing security functions and data with the USIM 

When an ISIM is used for IMS access, only the following options for sharing security functions and data are permitted: 
No security functions or data are shared; 
Only the sequence number checking mechanism is shared; 
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Only the algorithm is shared; 

Only the algorithm and sequence number checking mechanism are shared; 

The authentication key, authentication functions and the sequence number checking mechanism are shared. 

When a USIM is used for IMS access, only the following option is applicable: 

The authentication key, authentication functions and the sequence number checking mechanism are shared. 

NOTE: If the authentication keys and functions are shared, the cipher/integrity key sets generated during 

authentication are used with different cipher/integrity algorithms in CS/PS domain and IMS. Note that the 
same cipher/integrity key set is never used for both CS/PS domain and IMS because the authentication 
and key agreement protocol is run independently between CS/PS domain and IMS. Therefore there is no 
danger that the compromise of the cipher/integrity algorithm in one domain would lead to vulnerabilities 
in the other domain. 

If the mechanism and data for checking sequence numbers are shared then it shall be required for the authentication 
failure rate due to synchronization failures to be kept sufficiently low. In particular, the mechanism shall be required to 
support interleaving authentication in three domains (CS, PS and IMS). Example methods to achieve this are described 
in Annex G. 
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Annex A: 
Void 
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Annex B: 
Void 
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Annex C: 
Void 
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Annex D: 
Void 
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Annex E: 
Void 
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Annex F: 
Void 
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Annex G (informative): 
Management of sequence numbers 



The example sequence number management schemes in TS 33.102 [1] Informative Annex C can be used to ensure that 
the authentication failure rate due to synchronization failures to kept sufficiently low when the same sequence number 
mechanism and data is used for authentication in the PS/CS domains and in the IMS. This can be done by enhancing the 
method for the allocation of index values in the AuC so that authentication vectors distributed to different service 
domains shall always have different index values (i.e. separate ranges of index values are reserved for PS, CS and IMS 
operation). The AuC is required to obtain information about which type of service node has requested the authentication 
vectors. Reallocation of array elements to the IMS domain can be done in the AuC with no changes required to already 
deployed USIMs. 

As the possibility for out of order use of authentication vectors within the IMS service domain may be quite low, the 
number of PS or CS array elements that need to be reallocated to the IMS domain could be quite small. This means that 
the ability to support out of order authentication vectors within the PS and CS domains would not be significantly 
affected. 

Sequence number management is operator specific and for some proprietary schemes over the air updating of the UICC 
may be needed. 
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Annex H (normative): 

The use of "Security IVIechanism Agreement for SIP 

Sessions" [21] for security mode set-up 

The BNF syntax of RFC 3329 [21] , with the addition of the "aes-cbc" value for the "ealg" parameter and the "UDP- 
enc-tun" value for the "mode" parameter, is defined for negotiating security associations for semi-manually keyed 
IPsec in the following way: 

security-client = "Security-Client" HCOLON sec-mechanism *(COMMA sec-mechanism) 

security-server = "Security-Server" HCOLON sec-mechanism *(COMMA sec-mechanism) 

security-verify = "Security- Verify" HCOLON sec-mechanism *(COMMA sec-mechanism) 

sec-mechanism = mechanism-name *(SEM1 mech-parameters) 

mechanism-name = "ipsec- 3gpp" 

mech-parameters = ( preference / algorithm / protocol / mode / encrypt-algorithm / spi-c / spi-s / port-c / 
port-s ) 

preference = "q" EQUAL qvalue 

qvalue = ( "0" [ "." 0*3D1GIT ] ) / ( "1" [ "." 0*3("0") ] ) 

algorithm = "alg" EQUAL ( "hmac-md5-96" / "hmac-sha-1-96" ) 

protocol = "prot" EQUAL ( "ah" / "esp" ) 

mode = "mod" EQUAL ( "trans" / "tun"/ "UDP-enc-tun" ) 

encrypt-algorithm = "ealg" EQUAL ( "des-ede3-cbc" /"aes-cbc" / "null" ) 

spi-c = "spi-c" EQUAL spivalue 

spi-s = "spi-s" EQUAL spivalue 

spivalue = lODIGIT; to 4294967295 

port-c = "port-c" EQUAL port 

port-s = "port-s" EQUAL port 

port = 1*DIGIT 

The parameters described by the BNF above have the following semantics: 

Mechanism-name: For manually keyed IPsec, this field includes the value "ipsec- 3gpp". "ipsec- 3gpp" 
mechanism extends the general negotiation procedure of RFC 3329 [21] in the following way: 

1 The server shall store the Security-Client header received in the request before sending the response with the 
Security-Server header. 

2 The client shall include the Security-Client header in the first protected request. In other words, the first 
protected request shall include both Security-Verify and Security-Client header fields. 

3 The server shall check that the content of Security-Client headers received in previous steps (1 and 2) are the 

same. 

Preference: As defined in RFC 3329 [21]. 
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Algorithm: Defines the authentication algorithm. May have a value "hmac-md5-96" for algorithm defined in 
RFC 2403 [15], or "hmac-sha-1-96" for algorithm defined in RFC 2404 [16]. The algorithm parameter is 
mandatory. 

Protocol: Defines the IPsec protocol. May have a value "ah" for RFC 2402 [19] and "esp" for RFC 2406 [13]. If 
no Protocol parameter is present, the value will be "esp". 

NOTE: According to clause 6 only "esp" is allowed for use in IMS. 

Mode: Defines the mode in which the IPsec protocol is used. May have a value "trans" for transport mode, and 
value "tun" for tunneling mode. If no Mode parameter is present, the value will be "trans". 

NOTE: According to clause 6.3 ESP integrity shall be applied in transport mode i.e. only "trans" is allowed for 
use in IMS. 

Encrypt-algorithm: If present, defines the encryption algorithm. May have a value "des-ede3-cbc" for algorithm 
defined in RFC 2451 [20] or "aes-cbc" for the algorithm defined in IETF RFC 3602 [22] or "null" if encryption 
is not used. If no Encrypt-algorithm parameter is present, the algorithm will be "null". 

Spi-c: Defines the SPI number of the inbound SA at the protected client port. 

Spi-s: Defines the SPI number of the inbound SA at the protected server port. 

Port-c: Defines the protected client port. 

Port-s: Defines the protected server port. 

It is assumed that the underlying IPsec implementation supports selectors that allow all transport protocols supported by 
SIP to be protected with a single SA. 
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Annex I (normative): 

Key expansion functions for IPsec ESP 

Integrity Keys: 

If the selected authentication algorithm is HMAC-MD5-96 then IKesp = IKjm. 

If the selected authentication algorithm is HMAC-SHA-1-96 then IKesp is obtained from IKjm by appending 32 zero 
bits to the end of IKim to create a 160-bit string. 

Encryption Keys: 

Divide CKim into two blocks of 64 bits each: 

CKiM = CKiMl II CKiM2 

Where CK_IM1 are the 64 most significant bits and CK_IM2 are the 64 least significant bits. 
The key for DES-EDE3-CBC is then defined to be: 

CKesp = CKiMi II CKiM2 II CKjMi, 
after adjusting parity bits to comply with RFC 2451 [20]. 
If selected encryption algorithm is AES-CBC as specified in RFC 3602 [22] with 128 bit key then CKgsp = CKjm 
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Annex J (informative): 

Recommendations to protect the IMS from UEs bypassing 

the P-CSCF 

After the UE does a successful SIP REGISTER with the P-CSCF, malicious UE could try to send SIP messages directly 
to the S-CSCF. This could imply that the UE would be able to bypass the integrity protection provided by IPSec ESP 
between the UE and the P-CSCF. 

NOTE: The TS 24.229 [8] defines a trust domain that consists of the P-CSCF, the I-CSCF, the S-CSCF, the 

BGCF, the MGCF, the MRFC and all the AS:s that are not provided by 3rd party service providers. There 
are nodes in the edge of the trust domain that are allowed to provide with an asserted identity header. The 
nodes in the trust domain will trust SIP messages with asserted identity headers. The asserted identity 
information is useful as long as the interfaces in an operator's network can be trusted. 

If a UE manages to bypass the P-CSCF it presents at least the following problems: 

1) The P-CSCF is not able to generate any charging information. 

2) Malicious UE could masquerade as some other user (e.g. it could potentially send INVITE or BYE messages). 

The following recommendations for preventing attacks based on such misbehavior are given: 

Access to S-CSCF entities shall be restricted to the core network entities that are required for IMS operation, 
only. It shall be ensured that no UE is able to directly send IP packets to IMS-entities other than the required 
ones, ie. assigned P-CSCF, or HTTP servers. 

Impersonation of IMS core network entities at IP level (IP spoofing), especially impersonation of P-CSCFs by 
UEs shall be prevented. 

It is desirable to have a general protection mechanism against UEs spoofing (source) IP addresses in any access 
network providing access to IMS services. 

If the traffic is between two non-IMS CSCFs, it is recommended to use TLS mechanisms as specified in RFC 3261 [6]. 
This will mitigate the problems caused by misbehaviour of the UE. If neither intra-CSCF traffic nor CSCF-SEG traffic 
can be trusted and if this traffic is not protected by the NDS/IP, TS 33.210 [5] mechanisms, then physical protection 
measures or IP traffic filtering should be applied. This is anyhow not in the scope of 3GPP specification. 
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Annex K (informative): 
Security aspects of early IIVIS 



An interim security solution for early IMS implementations, that are not fully compliant with the IMS security 
architecture specified in the present document, is given in TR 33.978 [25]. 
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Annex L (Normative): 

Application to fixed broadband access 



L1 



Introduction 



This Annex specifies how the material in the main body and other normative Annexes of this document apply to the 
TISPANNGN [26]. 

NOTE 1: NGN specific abbreviations and terminology can be found in [26]. 

NOTE 2 : In the context of this Annex the term NGN-UE denotes the UE as defined in [26] 



L.2 Application of clause 4 



In 3GPP IMS, the ISIM is mandated to be present on UICC which is usually inserted within the MT component of the 
UE. In NGN-UEs, the ISIM shall be provided on the UICC, which shall be inserted within either : 

1) TheTE;or 

2) The IMS Residential Gateway (IRG). 

NOTE: For the exact definition of IRG will be pubhshed in ETSI TS 187 003: "TISPAN - NGN security: 
Secui-ity Architectme NGN Release 1". 



Where the TE and IRG each contain an UICC with ISIM application, the ISIM should be used in following order of 
preference TE, IRG. 
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Figure L.I 

Figure L. 1 redraws figure 1 of the main body of this document replacing the 3GPP specific transport domain by Generic 
IP transport domain. The following observations support figure L. 1 . 

1) The IMS is independent of the transport network 

2) Generic Entities (GE) equivalent to the 3GPP transport entities will be present in the Generic IP transport 
domain. 
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3) In the NGN architecture the AuC functionality is performed by the UPSF. 

4) The Security Associations (SA) (referring to the corresponding arrows in Figure X.l) are retained: 

a) SA-1, SA-3, SA-4 and SA-5 ai-e endorsed by this annex 

b) SA-2 is endorsed by this Annex with the extension to ensure transport across NAT/Firewall boundaries. 

There exist other interfaces and reference points in IMS, which have not been addressed above. Those interfaces and 
reference points reside within the IMS, either within the same security domain or between different security domains 
(See figure X.2). The protection of all such interfaces and reference points (which may include other subsystems) apart 
from the Gm reference point are protected as specified in TS 33.210 [5]. 
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Annex M (normative): 

Enhancements to the access security for IP based services 

to enable NAT traversal for signaling messages 

Note: section M.x (x= 1, 2, ...) in this annex corresponds to section x in the body of this specification. 

M.1 Scope 

It is assumed for the purposes of this annex that a NAT device may be located between the UE and the P-CSCF. Only 
NATs outside the borders of an IMS network are considered, i.e. NATs are assumed to be located at the subscriber's site 
or in the access network. If there are multiple NATs in either of these locations, it is assumed that their effect sums up 
in such a way that they can be treated as a single NAT so that the mechanisms described below are still valid. 

In this annex enhancements to sections 4 through 8 of this specification are specified that allow a UE and a P-CSCF to 
detect whether they are located behind a NAT device, to inform each other about their NAT traversal capabilities, and, 
if there is a NAT present, to securely communicate. If there is no NAT device present, the procedures of sections 6, 7 
and 8 apply. Examples of subscribers who are, in general, located behind a NAT device include subscribers accessing 
IMS via a DSL Une. 

Furthermore, this specification is restricted to the treatment of NAT traversal for signalling messages. Measures 
required for NAT traversal of media data are not considered in this specification. The general handling of NAT traversal 
for signalling messages is specified in TS 23.228 [3] and TS 24.229 [8]. Additional procedures for NAT traversal for 
protected signalling messages are specified in this specification. 

It should be noted that many NAT routers in residential sites do also apply port translation, which is typically denoted 
as Network Address and Port Translation (NAPT). For reasons of simplicity the term NAT is used, no matter whether 
only address or address and port translation is actually applied. 

NOTE: this annex is fully compliant with RFC 3948 [28], but only partially compliant with RFC 3947 [27] 

because 3GPP IMS security, as specified in this specification (main body and annexes), does not use IKE 
as the key management protocol for IPsec. 

M.2 References 

Additional references used in this section were incorporated directly into section 2. 

M.3 Definitions, symbols and abbreviations 

Additional definitions, symbols and abbreviations used in this section were incorporated directly into section 3. 

M.4 Overview of the security architecture 

The text in section 4 applies without changes. 

M.5 Security features 

The text in section 5 applies without changes. 
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M.6 Security mechanisms 

iVI.e.l Authentication and key agreement 

The text in section 6.1 applies without changes. 

I\/I.6.2 Confidentiality mechanisms 

If the local policy in P-CSCF requires the use of IMS specific confidentiality protection mechanism between UE and 
P-CSCF, IPsec ESP as specified in RFC 2406 [13] shall provide confidentiality protection of SIP signalling between the 
UE and the P-CSCF, protecting all SIP signalling messages at the IP level. IPSec ESP general concepts on Security 
Policy management, Security Associations and IP traffic processing as described in reference RFC 2401 [14] shall also 
be considered. ESP confidentiality shall be applied in transport mode between UE and P-CSCF either in transport mode 
if no NAT is present, or - if NAT traversal shall be supported - in UDP encapsulated tunnel mode. 

The method to set up ESP security associations (SAs) during the SIP registration procedure is specified in clause M.7. 
As a result of an authenticated registration procedure, two pairs of unidirectional SAs between the UE and the P-CSCF 
all shared by TCP and UDP, shall be established in the P-CSCF and later in the UE. One SA pair is for traffic between a 
client port at the UE and a server port at the P-CSCF and the other SA is for traffic between a client port at the P-CSCF 
and a server port at the UE. For a detailed description of the establishment of these security associations see clause M.7. 

The encryption key CKesp is the same for the two pairs of simultaneously established SAs. The encryption key CKesp is 
obtained from the key CKim established as a result of the AKA procedure, specified in clause M.6.1, using a suitable 
key expansion function. 

The encryption key expansion on the user side is done in the UE. The encryption key expansion on the network side is 
done in the P-CSCF. 

iVI.e.S integrity mechanisms 

IPsec ESP as specified in reference RFC 2406 [13] shall provide integrity protection of SIP signalling between the UE 
and the P-CSCF, protecting all SIP signalling messages at the IP level. IPSec ESP general concepts on Security Policy 
management. Security Associations and IP traffic processing as described in reference RFC 2401 [14] shall also be 
considered. ESP integrity shall be applied in transport mode between UE and P-CSCF either in transport mode if no 
NAT is present or - if NAT traversal shall be supported - in UDP encapsulated tunnel mode. 

The method to set up ESP security associations (SAs) during the SIP registration procedure is specified in clause M.7. 
As a result of an authenticated registration procedure, two pairs of unidirectional SAs between the UE and the P-CSCF, 
all shared by TCP and UDP, shall be established in the P-CSCF and later in the UE. One SA pair is for traffic between a 
client port at the UE and a server port at the P-CSCF and the other SA is for traffic between a client port at the P-CSCF 
and a server port at the UE. For a detailed description of the establishment of these security associations see clause M.7. 

The integrity key IKesp is the same for the two pairs of simultaneously established SAs. The integrity key IKesp is 
obtained from the key IKim established as a result of the AKA procedure, specified in clause M.6.1, using a suitable key 
expansion function. This key expansion function depends on the ESP integrity algorithm and is specified in Annex I of 
this specification. 

The integrity key expansion on the user side is done in the UE. The integrity key expansion on the network side is done 
in the P-CSCF. 

The anti-replay service shall be enabled in the UE and the P-CSCF on all established SAs. 

I\/I.6.4 Hiding mechanisms 

The text in section 6.4 applies without changes. 
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M.6.5 CSCF interoperating with proxy located in a non-IIVIS 
network 

The text in section 6.5 applies without changes. 



M.7 Security association set-up procedure 

The security association set-up procedure is necessary in order to decide what security services to apply and when the 
security services start. In the IMS authentication of users is performed during registration as specified in clause M.6.1. 
Subsequent signalling communications in this session will be integrity protected based on the keys derived during the 
authentication process. 



IVI.y.l Security association parameters 



For protecting IMS signalling between the UE and the P-CSCF it is necessary to agree on shared keys that are provided 
by IMS AKA, and a set of parameters specific to a protection method. The security mode setup (cf clause M.7. 2) is 
used to negotiate the SA parameters required for IPsec ESP with authentication and confidentiality, in accordance with 
the provisions in clauses 5.1.3 and M.6.2. 

The SA parameters that shall be negotiated between UE and P-CSCF in the security mode set-up procedure are: 

- Encryption algorithm 

The encryption algorithm is either DES-EDE3-CBC as specified in RFC 2451 [20] or AES-CBC as specified in 
RFC 3602 [22] with 128 bit key. 

Both encryption algorithms shall be supported by both, the UE and the P-CSCF. 

- Integrity algorithm 

NOTE: What is called "authentication algorithm" in RFC 2406 [13] is called "integrity algorithm" in this 
specification in order to be in line with the terminology used in other 3GPP specifications and, in 
particular, to avoid confusion with the authentication algorithms used in the AKA protocol. 

The integrity algorithm is either HMAC-MD5-96 [15] or HMAC-SHA-1-96 [16]. 

Both integrity algorithms shall be supported by both, the UE and the P-CSCF as mandated by RFC 2406 [13]. In 
the unlikely event that one of the integrity algorithms is compromised during the lifetime of this specification, 
this algorithm shall no longer be supported. 

NOTE: If only one of the two integrity algorithms is compromised then it suffices for the IMS to remain secure 
that the algorithm is no longer supported by any P-CSCF. The security mode set-up procedure 
(cf. clause 7.2) will then ensure that the other integrity algorithm is selected. 

- Mode 

The IPSec S A mode of operation shall depend on whether the UE is located behind a NAT device or not. If the 
UE is located behind a NAT device UDP encapsulated tunnel mode according to [28] shall be used. Otherwise 
transport mode shall be used. The set-up of security associations (cf. clause M.7. 2) allows the P-CSCF to detect 
whether the UE is located behind a NAT or not. 

- SPI (Security Parameter Index) 

The SPI is allocated locally for inbound SAs. The triple (SPI, destination IP address, security protocol) uniquely 
identifies an SA at the IP layer. The UE shall select the SPIs uniquely, and different from any SPIs that might be 
used in any existing SAs (i.e. inbound and outbound SAs). The SPIs selected by the P-CSCF shall be different 
than the SPIs sent by the UE, cf. clause 7.2. In an authenticated registration, the UE and the P-CSCF each select 
two SPIs, not yet associated with existing inbound SAs, for the new inbound security associations at the UE and 
the P-CSCF respectively. 
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NOTE: This allocation of SPIs ensures that protected messages in the uplink always differ from protected 
messages in the downlink in, at least, the SPI field. This thwarts reflection attacks. When several 
applications use IPsec on the same physical interface the SIP application should be allocated a separate 
range of SPIs. 

The following SA parameters are not negotiated: 

Life type: the life type is always seconds; 

SA duration: the SA duration has a fixed length of 2^^-l; 

NOTE: The S A duration is a network layer concept. From a practical point of view, the value chosen for "SA 
duration" does not impose any limit on the lifetime of an S A at the network layer. The S A lifetime is 
controlled by the SIP application as specified in clause M.7.4. 

Mode: transport mode; 

Key length: the length of the integrity key IKesp depends on the integrity algorithm. It is 128 bits for 
HMAC-MD5-96 and 160 bits for HMAC-SHA-1-96. 

Key length: the length of the encryption key depends on the encryption algorithm. The entropy of the key shall at 

least be 128 bits. 

Selectors if no NAT is present: 

Cf section 7.1 

Selectors if a NAT is present: 

The security associations (SA) have to be bound to specific parameters (selectors) of the SIP flows between UE and 
P-CSCF, i.e. source and destination IP addresses, transport protocols that share the SA, and source and destination 
ports. 

IP addresses are bound If a NAT is present, it is assumed that the UE is configured locally with a (e.g. private) IP 
address. When the UE communicates with the P-CSCF via the NAT device, the NAT allocates a binding, mapping the 
local IP address to two pairs of SAs, asa publicly routable IP address (called public IP address in the sequel) and 
perhaps also mapping the source port used in clause 6.3, as follows:the UDP or TCP packet to another port number. In 
the following, the term UE_IP_address always denotes the public IP address of the UE. 

NOTE: The IP addresses and ports used as selectors in IPsec tunnel mode are those of the inner IP header, in 

accordance with RFC2401 [14]. The inner IP addresses are always the public IP addresses. Please also 
note that the terminology used here may differ from that used in other scenarios, e.g. in VPN access to a 
corporate network, as in the latter scenario the inner IP address is not publicly routable in general. 

IP addresses: 

- inbound SA at the P-CSCF: 

The source and destination IP addresses associated with the S A are identical to those in the header of the IP 
packet in which the initial SIP REGISTER message was received by the P-CSCF. 

- outbound SA at the P-CSCF: 

the The source IP address bound to the outbound SA equals the destination IP address bound to the inbound 

SA; 

the destination IP address bound to the outbound SA equals the source IP address bound to the inbound SA. 

NOTE: This implies that the source and destination IP addresses in the header of the inner IP packet in which the 
protected SIP REGISTER message was received by the P-CSCF need to be the same as those in the 
header of the IP packet in which the initial SIP REGISTER message was received by the P-CSCF. 

NOTE: This further implies that the source address in the inbound SA and the destination address in the outbound 
SA at the P-CSCF equals the public IP address of the UE. 

- outbound SA at the UE: 

The source IP address bound to the outbound S A equals the public IP address of the UE. The public IP 
address is learned by the UE from the received parameter in the Via header in the 401 Unauthorized response 
to the initial unprotected REGISTER Request (cf Section M.7.2). 
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The destination IP address bound to the outbound S A equals the destination IP address in the header of the IP 
packet in which the initial SIP REGISTER was sent to the P-CSCF. 

- inbound SA at the UE: 

The source IP address bound to the inbound SA equals the destination IP address bound to the outbound SA; 
the destination IP address bound to the inbound SA equals the source IP address bound to the outbound SA. 

NOTE: For the handling of the outer IP header in UDP encapsulated tunnel mode, see section on "Data related to 
the use of UDP encapsulated tunnel mode" below. 

The transport protocol selector shall allow UDP and TCP. 

Ports: 

1 . The P-CSCF associates two ports, called port_ps and port_pc, with each pair of security assocations 
established in an authenticated registration. The ports port_ps and port_pc are different from the standard SIP 
ports 5060 and 5061. No unprotected messages shall be sent from or received on the ports port_ps and 
port_pc. From a security point of view, unprotected messages may be received on any port which is different 
from the ports port_ps and port_pc. The number of the ports port_ps and port_pc are communicated to the 
UE during the security mode set-up procedure, cf. clause 7.2. These ports are used with both, UDP and TCP. 
The use of these ports may differ for TCP and UDP, as follows: 

UDP case: the P-CSCF receives requests and responses protected with ESP from any UE on the port 
port_ps (the"protected server port"). The P-CSCF sends requests and responses protected with ESP to a 
UE on the port port_pc (the "protected client port"). 

TCP case: the P -CSCF, if it does not have a TCP connection towards the UE yet, shall set up a TCP 
connection from its port_pc to the port port_us of the UE before sending a request to it.. 

NOTE: Both the UE and the P-CSCF may set up a TCP connection from their client port to the other end's server 
port on demand. An already existing TCP connection may be reused by both the P-CSCF or the UE; but it 
is not mandatory. 

NOTE: The protected server port port_ps stays fixed for a UE until all IMPUs from this UE are de-registered. It 
may be fixed for a particular P-CSCF over all UEs, but there is no need to fix the same protected server 
port for different P-CSCFs. 

NOTE: The distinction between the UDP and the TCP case reflects the different behaviour of SIP over UDP and 
TCP, as specified in section 18 of RFC 3261 [6]. 

NOTE: The handling of the protected ports is the same, irrespective of whether transport or UDP encapsulated 
tunnel mode is used. 

2. The UE associates two ports, called port_us and port_uc, with each pair of security assocations established in 
an authenticated registration. The ports port_us and port_uc are different from the standard SIP ports 5060 
and 506 1 . No unprotected messages shall be sent from or received on the ports port_us and port_uc. From a 
security point of view, unprotected messages may be received on any port which is different from the ports 
portjus and portjuc. The number of the ports port_us and port_uc are communicated to the P-CSCF during 
the security mode set-up procedure, cf clause 7.2. These ports are used with both, UDP and TCP. The use of 
these ports may differ for TCP and UDP, as follows: 

UDP case: the UE receives requests and responses protected with ESP on the port port_us (the "protected 
server port"). The UE sends requests and responses protected with ESP on the port portjuc (the 
"protected client port"). 

TCP case: the UE, if it does not have a TCP connection towards the P-CSCF yet, shall set up a TCP 
connection to the port port_ps of the P-CSCF before sending a request to it. 

NOTE: Both the UE and the P-CSCF may set up a TCP connection from their client port to the other end's server 
port on demand. An already existing TCP connection may be reused by both the P-CSCF or the UE, but it 
is not mandatory. 

NOTE: The protected server port portjus stays fixed for a UE until all IMPUs from this UE are de-registered. 
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NOTE: The distinction between the UDP and the TCP case reflects the different behaviour of SIP over UDP and 
TCP, as specified in section 18 of RFC 3261 [6] 

NOTE: The handling of the protected ports is the same, irrespective of whether transport or UDP encapsulated 
tunnel mode is used. 

3. The P-CSCF is allowed to receive only REGISTER messages and error messages on unprotected ports. All 
other messages not arriving on a protected port shall be either discarded or rejected by the P-CSCF. 

4. The UE is allowed to receive only the following messages on an unprotected port: 
- responses to unprotected REGISTER messages; 

error messages. 

All other messages not arriving on a protected port shall be rejected or silently discarded by the UE. 

Data related to the use of UDP encapsulated tunnel mode 

Tunnel endpoint addresses and header construction for tunnel mode: 

In case UDP encapsulated tunnel mode is selected, an "outer" IP header is added to protected packets exchanged 
between UE and P-CSCF, following the rules of tunnel mode processing according to [14]. While the IP 
addresses of the inner IP header are as specified above in the section about "Selectors", the IP addresses of the 
outer IP header shall be selected as follows: 

- P-CSCF: 

For the outbound SA at the P-CSCF the source address shall be the IP address of the P-CSCF, the destination 
address shall be the public IP address of the UE. For the inbound S A only the destination address of the outer IP 
header is used to identify the S A at the P-CSCF, together with the SPI. This address is the IP address of the P- 
CSCF. 

-UE: 

For the outbound S A at the UE the source address shall be the local IP address of the UE, the destination address 
shall be the address of the P-CSCF as in the destination address of the IP header of the initial unprotected 
REGISTER message. For the inbound SA only the destination address of the outer IP header is used to identify 
the S A at the UE. This address is the local IP address of the UE. 

Other data of the outer IP header (apart from IP addresses) shall be constructed as specified in [14]. 

Ports used in the encapsulating UDP header: 

In case UDP encapsulated tunnel mode is selected, an encapsulating UDP header is inserted after the outer IP 
header. With respect to the ports used in the UDP header, the following rules shall be applied in accordance with 
standard [28]: 

-UE: 

Each protected and UDP encapsulated packet shall use port 4500 as source and destination port in the 

encapsulating UDP header. 

- P-CSCF: 

When the UE sends an UDP encapsulated packet towards the P-CSCF with the ports as described in the previous 
paragraph, the NAT will change the source port to a port different from 4500. This port is called port_Uenc. 
When the P-CSCF receives the first protected and UDP encapsulated message from the UE it shall store 
port_Uenc (cf. Section 7.2). From then on, all protected UDP encapsulated messages from the P-CSCF to the UE 
shall use port 4500 as source port and port_Uenc as destination port in the encapsulating UDP header. 

The following rules apply: 

1. For each unidirectional SA which has been established and has not expired, the SIP application at the P-CSCF 
stores at least the following data: (UE_IP_address, UE_protected_port, P-CSCF_protected_port, SPI, IMPI, 
IMPUl, ... , IMPUn, lifetime, mode) in an "SA_table". The pair (UE_protected_port, P-CSCF_protected_port) 
equals either (port_uc, port_ps) or {portjus, port_pc). 

NOTE: The SPI is only required when initiating and deleting SAs in the P-CSCF. The SPI is not exchanged 
between IPsec and the SIP layer for incoming or outgoing SIP messages. 
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2. The SIP application at the P-CSCF shall check upon receipt of a protected REGISTER message that the source 
IP address in the packet headers coincide with the UE's IP address inserted in the Via header of the protected 
REGISTER message. If the Via header does not explicitly contain the UE's IP address, but rather a symbolic 
name then the P-CSCF shall first resolve the symbolic name by suitable means to obtain an IP address. 

3. The SIP application at the P-CSCF shall check upon receipt of an initial REGISTER message or a re- 
REGISTER message that the pair (UE_IP_address, UE_protected_client_port), where the UE_IP_address is the 
source IP address in the packet header and the protected client port is sent as part of the security mode set-up 
procedure (cf. clause 7.2), has not yet been associated with entries in the "SA_table". In addition, if the P-CSCF 
has detected that the UE is located behind a NAT (cf. Section A 7.2), the P-CSCF shall check upon receipt of an 
initial (unprotected) REGISTER message, or a REGISTER message protected with UDP encapsulated tunnel 
mode, that the pair (UE_IP_address, UE_protected_server_port) has not yet been associated with entries in the 
"SA_table". Here the UE_IP_address is the source IP address in the packet header, and the protected client and 
server ports are sent as part of the security mode set-up procedure (cf clause A 7.2). 

NOTE: In case of multiple UEs behind the same NAT, the same public IP address may be assigned by the NAT 
to two different UEs. Therefore, the P-CSCF shall not accept registration attempts from UEs with the 
same address and protected server port in order to ensure unambiguous addressing of SIP messages sent 
towards the UE, using the protected server port. 

Furthermore, the P-CSCF shall check that, for any one IMPI, no more than six SAs per direction are stored at 
any one time. If these checks are unsuccessful the registration is aborted and a suitable error message is sent to 
the UE. 

NOTE: According to clause M.7.4 on SA handling, at most six SAs per direction may exist at a P-CSCF for one 
user at any one time. 

4. For each incoming protected message the SIP application at the P-CSCF shall verify that the correct inbound SA 
according to clause M.7.4 on SA handling has been used. The SA is identified by the triple (UE_IP_address, 
UE_protected_port, P-CSCF_protected_port) in the "SA_table". The SIP application at the P-CSCF shall further 
ensure that the user associated with the SA, which was used to protect the incoming message from the UE, is 
identical to the user who is associated at SIP level with the message sent by the P-CSCF towards the network. 

NOTE: Not all SIP messages necessarily contain public or private identities, e.g. subsequent messages in a 
dialogue. Other information, e.g. a dialogue identifier, may be used to associate the message with a user at SIP 
level. 



5. For each unidirectional SA which has been established and has not expired, the SIP application at the UE stores 
at least the following data: (UE_IP_address, UE_protected_port, P-CSCF_protected_port, SPI, lifetime, mode) 
in an "SA_table". The pair (UE_protected_port, P-CSCF_protected_port) equals either {port_uc, port_ps) or 
{portjus, port_pc). 

NOTE: The SPI is only required to initiate and delete SAs in the UE. The SPI is not exchanged between IPsec 
and the SIP layer for incoming or outgoing SIP messages. 

6. When establishing a new pair of SAs (cf. clause 6.3) the SIP application at the UE shall ensure that the 
selected numbers for the protected ports do not correspond to an entry in the "SA_table". Furthermore, the UE 
should select port numbers (pseudo-)randomly from a sufficiently large set of numbers not yet allocated at the 
UE. When the UE receives an error message indicating a collision of a pair (IP address, port), according to rule 3 
above, the UE may retry the registration with differently selected port numbers. 

NOTE: The UE should select port numbers (pseudo-)randomly for two reasons: 

1) to avoid collisions of pairs (IP address, port) at the P-CSCF, cf. rule 3 above. 

2) to thwart a limited form of a Denial of Service attack. UMTS PS access link security also helps to 
thwart this attack. 



7. For each incoming protected message the SIP application at the UE shall verify that the correct inbound SA 
according to clause M.7.4 on SA handling has been used. The SA is identified by the pair (UE_protected_port, 
P-CSCF_protected_port) in the "SA table". 

NOTE: If the integrity check of a received packet fails then IPsec will automatically discard the packet. 
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M.7.2 Set-up of security associations (successful case) 

The set-up of security associations is based on RFC 3329 [21]. Annex H of this specification shows how to use 
RFC 3329 [21] for the set-up of security associations. 

In this clause the normal case is specified i.e. when no failures occurs. Note that for simplicity some of the nodes and 
messages have been omitted. Hence there are gaps in the numbering of messages, as the 1-CSCF is omitted. 

For the purpose of the description of the message processing in case UDP encapsulated tunnel mode is used, a 
conceptual functional element called "UDP encapsulation function" is used. The UDP encapsulation function handles 
all tasks relevant to the UDP encapsulation processing, i.e. the addition and removal of UDP headers to packets. In that 
sense it does not perform any IPSec processing as such. From an implementation point of view, it is immaterial whether 
the UDP encapsulation function and the IPSec processing are combined or kept separate. On the network side, the UDP 
encapsulation function may reside on the P-CSCF or in a separate device. 

Relation of this Annex with the NAT traversal functionality specified in TS 24.229 [8]: 

If the UE is located behind a NAT, the unprotected REGISTER message and the corresponding unprotected 
response (messages SMI and SM6) shall be handled according to Annex F of [8]. For SIP messages protected with 
UDP encapsulated tunnel mode, the P-CSCF shall rewrite only the SDP according to Annex F.3 of [8], and shall not 
perform the rewriting of the SIP headers specified in Annex F.2 of [8]. The P-CSCF recognises from the mode 
parameter in the SA table (cf. section 7.1) that UDP encapsulated tunnel mode is used. 



UE P-CSCF S-CSCF 



(SMI) Register 

> 

^ (SM2) Register 



-» 



(SM6) 4xx AuthCiiallenge 
< 



(SM7) Register 



(SM4) 4xx Auth_Challenge 



(SMS) Register 



(SMIO) 2xx Auth_01; 
< 



(SMI 2) 2xx AuthOk 



Figure M.8 

The UE sends a Register message towards the S-CSCF to register the location of the UE and to set-up the security 
mode, cf. clause M.6.1. In order to start the security mode set-up procedure, the UE shall include a Security-setup-line 
in this message. 

The Security-setup-line in SMI contains the Security Parameter Index values and , the protected ports selected by the 
UE. It also contains and a list of identifiers for the integrity and encryption algorithms, which the UE supports. It shall 
also contain the list of IPSec modes (i.e. transport and/or UDP encapsulated tunnel mode) supported by the UE. 
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SM1: 



REGISTER(Security-setup = SPI_U, Port_U, UE integrity and encryption algoritlims list, IPSec mode list) 

SPI_U is the symbolic name of a pair of SPI values (cf. clause 7.1) (spi_uc, spi_us) that the UE selects. spi_uc is the 
SPI of the inbound SA at UE's the protected client port, and spi_us is the SPI of the inbound SA at the UE's protected 
server port. The syntax of spi_uc and spi_us are defined in Annex H. 

Port_U is the symbolic name of a pair of port numbers {port_uc, port_us) as defined in clause 7.1. The syntax of 
port_uc and port_us is defined in Annex H. 

Upon receipt of SMI, the P-CSCF temporarily stores the parameters received in the Security-setup-line together with 
the UE's IP address from the source IP address of the IP packet header, the IMPI and IMPU. Upon receipt of SM4, the 
P-CSCF adds the keys IKim and CKim received from the S-CSCF to the temporarily stored parameters. 

A Release 6 P-CSCF shall propose SA alternatives for Release 5 and Release 6 UE's since the UE may or may not 
support confidentiality protection. The P-CSCF selects the SPI for the inbound SA. The P-CSCF then selects the SPIs 
for the inbound SAs. The same SPI number shall be used for Release 5 and Release 6 options. The P-CSCF shall define 
the SPIs such that they are unique and different from any SPIs as received in the Security-setup-line from the UE. 

Upon receipt of SMI, the P-CSCF temporarily stores the parameters received in the Security-setup-line together with 
the UE's IP address from the source IP address of the IP packet header, the IMPI and IMPU. 

If the source IP address of the IP packet header is different from the address contained in the top-most Via header, the 
P-CSCF concludes that the UE is located behind a NAT device parameter with the source IP address to the Via header 
and acts as described in Annex F of TS 24.229 [8]. In this case the P-CSCF concludes that the UE is located behind a 
NAT device. If the UE has not signalled support for UDP encapsulated tunnel mode in message SMI the P-CSCF shall 
silently discard the message and stop performing any further steps. 

Otherwise, if the source IP address of SMI matches the UE address in the Via header, the P-CSCF concludes that the 
UE is not located behind a NAT. The P-CSCF then continues with the set-up of security associations as specified in 
section 7.2, otherwise it continues as specified in this annex. 

NOTE: If the top-most Via header contains a domain name the P-CSCF shall perform the appropriate DNS 
procedures in order to retrieve the address information to be used for the comparison, as specified in 
AnnexFofTS 24.229 [8]. 

Upon receipt of SM4, the P-CSCF adds the keys IKim and CKim received from the S-CSCF to the temporarily stored 
parameters. 

The P-CSCF then selects the SPIs for the inbound SAs. The P-CSCF shall define the SPIs such that they are unique and 
different from any SPIs as received in the Security-setup-line from the UE. 

NOTE: This rule is needed since the UE and the P-CSCF use the same key for inbound and outbound traffic. 

In order to determine the integrity and encryption algorithm the P-CSCF proceeds as follows: the P-CSCF has a list of 
integrity and encryption algorithms it supports, ordered by priority, cf. Annex H. Release 6 algorithms shall have higher 
priority than Release 5 algorithms. The P-CSCF selects the first algorithm combination on its own list which is also 
supported by the UE. If the UE did not include any confidentiality algorithm in SMI then the P-CSCF shall either select 
the NULL encryption algorithm or abort the procedure, according to its policy on confidentiality. 

NOTE: It should be noted that, if the P-CSCF policy requires confidentiality, then all UEs with no encryption 
support would be denied access to the IMS network. This would apply in particular to UEs, which 
support only a Release 5-version of this specification or only Early IMS according to [25]. 



The P-CSCF then establishes two new pairs of SAs in the local security association database. 

In case the P-CSCF has discovered before that the UE is located behind a NAT, it informs the UDP encapsulation 
function about the IPSec S A data relevant for the UDP encapsulation process. This data consists of the IP source and 
destination addresses of the outer IP headers and the SPIs used in all four SAs (cf. section M.6.3) established. At this 
point in time the UDP encapsulation function creates a table, the "UDP encapsulation table", with the following 
contents: 
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"UDP Encapsulation Table on the network side " 




SA1 


SA2 


SA3 


SA4 


Src Addr 


PCSCF 


UE_pub 


PCSCF 


UE_pub 


Dest Addr 


UE_pub 


PCSCF 


UE_pub 


PCSCF 


Src Port 


4500 


undef 


4500 


undef 


Dest Port 


undef 


4500 


undef 


4500 


SPI 


SPI_us 


SPLps 


SPI_uc 


SPLpc 



The P-CSCF shall use port 4500 as the source port for UDP encapsulated packets towards the UE. The P-CSCF will 
also receive packets from the UE with and as the destination port 4500. This is the IPSec standard port for UDP 
encpasulated IPSec packets (see [28]). The source port for packets received by the P-CSCF from the UE and the 
destination port for packets sent by the P-CSCF towards the UE is not known yet and can only be learned in a later step 
(see below). 

NOTE: a corresponding table on the UE side is not required as the ports used by the UE are not affected by the 
NAT. 

The Security-setup-line in SM6 contains the SPIs and the ports assigned by the P-CSCF. It also contains a list of 
identifiers for the integrity and encryption algorithms, which the P-CSCF supports. The only exception from this is the 
case that the P-CSCF is configured to never apply confidentiality. In this case, it shall not include encryption algorithms 
to the Security-setup-line in SM6. 

Furthermore, the P-CSCF indicates the IPSec mode of operation. In case the P-CSCF detected that the UE is behind a 
NAT, it indicates UDP encapsulated tunnel mode, otherwise transport mode is indicated. 

NOTE: The P-CSCF may be configured to never apply confidentiality, e.g. because it trusts on the encryption 
provided by the underlying access network. In this case, the P-CSCF acts according to Release 5 
specifications, and does not include encryption algorithms to the Security-setup-line in SM6. If the P- 
CSCF is configured to apply confidentiality whenever the UE supports it then the P-CSCF always 
includes the encryption algorithms in SM6, which it supports, even if the UE did not include encryption 
algorithms in SMI. This is to thwart bidding down attacks. P-CSCF may be configured to trust on the 
encryption provided by the underlying access network. In this case, the P-CSCF acts according to 
Release 5 specifications, and does not include encryption algorithms to the Security-setup-line in SM6. 



SM6: 

4xx Auth_Challenge(Security-setup 

ivode ) 



SPI_P, Port_P, P-CSCF integrity and encryption algoritlims list), IPSec 



SPI_P is the symbolic name of the pair of SPI values (cf. clause 7.1) {spijc, spi_ps) that the P-CSCF selects, spijc is 
the SPI of the inbound SA at the P-CSCF' s protected client port, and spi_ps is the SPI of the inbound SA at the 
P-CSCF' s protected server port. The syntax of spij5c and spi_ps is defined in Annex H. 

Port_P is the symbolic name of the port numbers (port_pc, port_ps) as defined in clause 7.1. The syntax of Port_P is 
defined in Annex H. 

Upon receipt of SM6, the UE determines the integrity and encryption algorithms as follows: the UE selects the first 
integrity and encryption algorithm combination on the list received from the P-CSCF in SM 6 which is also supported 
by the UE. 

NOTE: Release 5 UE will not support any encryption algorithms, and will choose the first Release 5 integrity 
algorithm on the list received from the P-CSCF in SM6. 

The UE shall eitherconfigure UDP encapsulated tunnel mode or determine the IPsec mode according to the mode 
information contained in SM6. If no mode information is included in SM6, the UE shall first check whether it is located 
behind a NAT by checking for the presence of a "received" -parameter in the Via header of SM6. If the UE is not 
located behind a NAT, the UE assumes transport mode, otherwise it aborts the communication. If transport mode is 
used the UE continues with the set-up of security associations as specified in section 7.2, otherwise it continues as 
specified in this annex. 
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The UE then proceeds to estabhsh two new pairs of S As in the local SAD. 

The UE shall integrity and confidentiality protect SM7 and all following SIP messages. 

Furthermore the integrity and encryption algorithms list, SPI_P, and Port_P received in SM6, and SPI_U, Port_U sent 
in SMI shall be included: 



SM7: 

REGISTER(Security-setup = SPI_U, Port_U, SPI_P, Port_P, P-CSCF integrity and encryption algorithms list) 

After receiving SM7 from the UE,If UDP encapsulated tunnel mode is used, the UE shall use the following addresses 
and ports in the various headers of message SM7: 

SIP header: 

In the Via and Contact header the UE shall use its public IP address and protected server port. The UE learns its 
public IP address by inspecting the received parameter in the top-most Via header included in message SM6, in case 
such a parameter is present. 

IP and UDP/TCP headers are used as specified in M.7.1. 

If UDP encapsulated tunnel mode is applied, the UE shall start sending keep alive messages according to [28]. This 
ensures that the NAT binding is kept alive for the duration of the registration. 

When SM 7 arrives at the P-CSCF it is at first processed by the UDP encapsulation function. The UDP encapsulation 
function can now learn port_Uenc, which the NAT has chosen for the UDP encapsulated packet. The UDP 
encapsulation function inserts this port in the UDP encapsulation table, so that the table is complete. 



"UDP Encapsulation Table" on the network side 




SA1 


SA2 


SA3 


SA4 


Src Addr 


PCSCF 


UE_pub 


PCSCF 


UE_pub 


Dest Addr 


UE_pub 


PCSCF 


UE_pub 


PCSCF 


Src Port 


4500 


Port_Uenc 


4500 


Port_Uenc 


Dest Port 


Port_Uenc 


4500 


Port_Uenc 


4500 


SPI 


SPI_us 


SPLps 


SPI_uc 


SPLpc 



The UDP encapsulation function removes the UDP header from the IP packet and hands it over to the IPSec 
processing. 

After successful IPSec processing the SIP application in the P-CSCF shall check whether the integrity algorithms list, 
SPI_P and Port_P received in SM7 is identical with thethe corresponding parameters sent in SM6. It further checks 
whether SPI_U and Port_t/ received in SM7 are identical with those received in SMI. If these checks are not successful 
the registration procedure is aborted. 

The P-CSCF shall include in SMS information to the S-CSCF that the received message from the UE was integrity 
protected as indicated in clause 6.1.5. The P-CSCF shall add this information to all subsequent REGISTER messages 
received from the UE that have successfully passed the integrity check in the P-CSCF. 



SMS: 



REGISTER(lntegrity-Protection = Successful, IMPi; 

The P-CSCF finally sends SM12 to the UE. SM12 does not contain information specific to security mode setup (i.e. a 
Security-setup line), but with sending SM12 not indicating an error the P-CSCF confirms that security mode setup has 
been successful. 

After receiving SMI 2 not indicating an error, the UE can assume the successful completion of the security-mode setup. 
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An example of how to make use of two pairs of unidirectional SAs is illustrated in the figure below with a set of 
example message exchanges protected by the respective IPsec SAs where the INVITE and following messages are 
assumed to be carried over TCP. 



UE 



portjuc 



P-CSCF 



Register (SMI) 



401 Unauthorised (SM6) 



RANDIIAUTN 



Register (SM7) 
RES 



..O.K..(.SM12) 



.Unprotected 
■■Protected by SA pair 1 
"Protected by SA pair 2 



port_ps 



Invite 



portjus- 



_1 80_Ringing , 



200 OK 



port_pc 



Figure 9 



M.7.3 Error cases in the set-up of security associations 
M. 7.3.1 Error cases related to IIVIS AKA 

Errors related to IMS AKA failures are specified in clause 6.1. However, this clause additionally describes how these 
shall be treated, related to security setup. 



7.3.1.1 



User authentication failure 



In this case, SM7 fails integrity check by IPsec at the P-CSCF if the IKim derived from RAND at UE is wrong. The SIP 
application at the P-CSCF never receives SM7. It shall delete the temporarily stored SA parameters associated with this 
registration after a time-out. 

In case IKjm was derived correctly, but the response was wrong the authentication of the user fails at the S-CSCF due to 
an incorrect response. The S-CSCF shall send a 4xx Auth_Failure message to the UE, via the P-CSCF, which may pass 
through an already established SA. Afterwards, both, the UE and the P-CSCF shall delete the new SAs. 



7.3.1.2 



Network authentication failure 



If the UE is not able to successfully authenticate the network, the UE shall send a REGISTER message which may pass 
through an already established SA, indicating a network authentication failure, to the P-CSCF. The P-CSCF deletes the 
new SAs after receiving this message. 



7.3.1.3 



Synchronisation failure 



In this situation, the UE observes that the AUTN sent by the network in SM6 contains an out-of-range sequence 
number. The UE shall send a REGISTER message to the P-CSCF, which may pass through an akeady established SA, 
indicating the synchronization failure. The P-CSCF deletes the new SAs after receiving this message. 



7.3.1.4 



Incomplete authentication 



If the UE responds to an authentication challenge from a S-CSCF, but does not receive a reply before the request times 
out, the UE shall start a registration procedure if it still requires any IM services. The first message in this registration 
should be protected with an SA created by a previous successful authentication if one exists. 
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When the P-CSCF receives a challenge from the S-CSCF and creates the corresponding SAs during a registration 
procedure, it shall delete any information relating to any previous registration procedure (including the SAs created 
during the previous registration procedure). 

If the P-CSCF deletes a registration SA due to its lifetime being exceeded, the P-CSCF should delete any information 
relating to the registration procedure that created the SA. 

The text in section 7.3.1 applies without changes. 

M.7.3.2 Error cases related to the Security-Set-up 
M.7.3.2.1 Proposal unacceptable to P-CSCF 

In this case the P-CSCF cannot accept the proposal set sent by the UE in the Security-Set-up command of SMI. The 
P-CSCF shall respond to SMI indicating a failure, by sending an error response to the UE. 

M. 7. 3. 2.2 Proposal unacceptable to UE 

If the P-CSCF sends in the security-setup line of SM6 a proposal that is not acceptable for the UE, the UE shall abandon 
the registration procedure. 

M. 7. 3. 2.3 Failed consistency check of Security-Set-up lines at the P-CSCF 

The P-CSCF shall check whether authentication and encryption algorithms list received in SM7 is identical with the 
authentication and encryption algorithms list sent in SM6. If this is not the case the registration procedure is aborted. 
(Cf clause 7.2). 

M. 7. 3. 2.4 Missing NAT traversal capabilities in the presence of a NAT 

In case the P-CSCF detects the presence of a NAT, but the UE or the P-CSCF do not support NAT traversal as specified 
in this annex, the P-CSCF shall abort the procedure. 



M.7.4 Authenticated re-registration 



Every registration that includes a user authentication attempt produces new security associations. If the authentication is 
successful, then these new security associations shall replace the previous ones. This clause describes how the UE and 
P-CSCF handle this replacement and which SAs to apply to which message. 

When security associations are changed in an authenticated re-registration then the protected server ports at the UE 
(port_us) and the P-CSCF (port_ps) shall remain unchanged, while the protected client ports at the UE (port_uc) and 
the P-CSCF (port_pc) shall change. For the definition of these ports see clause 7.1. 

If the UE has an already active pair of security associations, then it shall use this to protect the REGISTER message. If 
the S-CSCF is notified by the P-CSCF that the REGISTER message from the UE was integrity-protected it may decide 
not to authenticate the user by means of the AKA protocol. However, the UE may send unprotected REGISTER 
messages at any time. In this case, the S-CSCF shall authenticate the user by means of the AKA protocol. In particular, 
if the UE considers the SAs no longer active at the P-CSCF, e.g., after receiving no response to several protected 
messages, then the UE should send an unprotected REGISTER message. 

Security associations may be unidirectional or bi-directional. This clause assumes that security associations are 
unidirectional, as this is the general case. For IP layer SAs, the lifetime mentioned in the following clauses is the 
lifetime held at the application layer. Furthermore deleting an S A means deleting the SA from both the application and 
IPsec layer. The message numbers, e.g. SMI, used in the following clauses relate to the message flow given in 
clause 6.1.1. 
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M.7.4.1 Void 

M.7.4. 1a Management of security associations in tine UE 

The UE shall be involved in only one registration procedure at a time, i.e. the UE shall remove any data relating to any 
previous incomplete registrations or authentications, including any SAs created by an incomplete authentication. 

The UE may start a registration procedure with two existing pairs of SAs. These will be referred to as the old SAs. The 
authentication produces two pairs of new SAs. These new SAs shall not be used to protect non-authentication traffic 
until noted during the authentication flow. In the same way, certain messages in the authentication shall be protected 
with a particular SA. If the UE receives a message protected with the incorrect SA, it shall discard the message. 

A successful authentication proceeds in the following steps: 

The UE sends the SMI message to register with the IMS. If SMI was protected, it shall be protected with the old 
outbound SA. 

The UE receives an authentication challenge in a message (SM6) from the P-CSCF. This message shall be 
protected with the old inbound SA if SMI was protected and unprotected otherwise. 

If this message SM6 can be successfully processed by the UE, the UE creates the new SAs, which are derived 
according to clause 7.1. The lifetime of the new SAs shall be set to allow enough time to complete the 
registration procedure. If SMI was protected and UDP encapsulated tunnel mode is used in the old SAs, the new 
SAs shall also be configured in with UDP encapsulated tunnel mode. The UE then sends its response (SM7) to 
the P-CSCF, which shall be protected with the new outbound SA. Meanwhile, if SMI was protected, the UE 
shall use the old SAs for messages other than those in the authentication, until a successful message of new 
authentication is received (SM12); if SMI was unprotected, the UE is not allowed to use IMS service until it 
receives an authentication successful message (SM12). 

The UE receives an authentication successful message (SM12) from the P-CSCF. It shall be protected with the 
new inbound SA. 

After the successful processing of this message by the UE, the registration is complete. The UE sets the lifetime 
of the new SAs such that it either equals the latest lifetime of the old SAs or it will expire shortly after the 
registration timer in the message, depending which gives the SAs the longer life. For further SIP messages sent 
from UE, the new outbound SAs are used, with the following exception: when a SIP message is part of a 
pending SIP transaction it may still be sent over the old S A. A SIP transaction is called pending if it was started 
using an old SA. When a further SIP message protected with a new inbound SA is successfully received from the 
P-CSCF, then the old SAs shall be deleted as soon as either all pending SIP transactions have been completed, or 
have timed out. The old SAs shall be always deleted when the lifetime is expired. This completes the SA 
handling procedure for the UE. 

A failure in the authentication can occur for several reasons. If the SMI was not protected, then no protection shall be 
applied to the failure messages, except the user authentication failure message which shall be protected with the new 
SA. If SMI was protected, the old SAs shall be used to protect the failure messages. In both cases, after processing the 
failure message, the UE shall delete the new SAs. 

The UE shall monitor the expiry time of registrations without an authentication and if necessary increase the lifetime of 
the SAs created by the last successful authentication such that it will expire shortly after the registration timer in the 
message. 

NOTE: In particular this means that the lifetime of a SA is never decreased. 

The UE shall delete any SA whose lifetime is exceeded. The UE shall delete all SAs it holds once all the IMPUs are de- 
registered. 

M.7.4.2 Void 

M.7.4. 2a Management of security associations in tine P-CSCF 

When the S-CSCF initiates an authentication by sending a challenge to the UE, the P-CSCF may already contain 
existing SAs from previously completed authentications. It may also contain two existing pairs of SAs from an 
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incomplete authentication. These will be referred to as the old and registration SAs respectively. The authentication 
produces two pairs of new SAs. These new SAs shall not be used to protect non-authentication traffic until noted during 
the authentication flow. Similarly certain messages in the authentication shall be protected with a particular SA. If the 
P-CSCF receives a message protected with the incorrect SA, it shall discard the message. 

The P-CSCF associates the IMPI given in the registration procedure and all the successfully registered IMPUs related to 
that IMPI to an SA. 

A successful authentication proceeds in the following steps: 

The P-CSCF receives the SMI message. If SMI is protected, it shall be protected with the old inbound SA. 

The P-CSCF forwards the message containing the challenge (SM6) to the UE. This shall be protected with the 
old outbound SA, if SMI was protected and unprotected otherwise. 

The P-CSCF then creates the new SAs, which are derived according to clause 7.1. The expiry time of the new 
SAs shall be set to allow enough time to complete the registration procedure. If SMI was protected and UDP 
encapsulated tunnel mode is used in the old SAs, the new SAs shall also be configured with UDP encapsulated 
tunnel mode. The registration SAs shall be deleted if they exist. 

The P-CSCF receives the message carrying the response (SM7) from the UE. It shall be protected using the new 
inbound SA. If SMI was protected, the old SAs are used to protect messages other than those in the 
authentication. 

The P-CSCF forwards the successful registration message (SM12) to the UE. It shall be protected using the new 
outbound SA. This completes the registration procedure for the P-CSCF. The P-CSCF sets the expiry time of the 
new SAs such that they either equals the latest lifetime of the old SAs or it will expire shortly after the 
registration timer in the message, depending which gives the SAs the longer life. 

After SM12 is sent, the P-CSCF handles the UE related SAs according to following rules: 

If there are old SAs, but SMI belonging to the same registration procedure was received unprotected, the 
P-CSCF considers error cases happened, and assumes UE does not have those old SAs for use. In this case 
the P-CSCF shall remove the old SAs. 

If SMI belonging to the same registration procedure was protected with an old valid SA, the P-CSCF keeps 
this inbound SA and the corresponding three SAs created during the same registration with the UE active, 
and continues to use them. Any other old SAs are deleted. When the old SAs have only a short time left 
before expiring or a further SIP message protected with a new inbound SA is successfully received from the 
UE, the P-CSCF starts to use the new SAs for outbound messages with the following exception: when a SIP 
message is part of a pending SIP transaction it may still be sent over the old S A. A SIP transaction is called 
pending if it was started using an old S A. The old SAs are then deleted as soon as all pending SIP 
transactions have been completed, or have timed out. The old SAs are always deleted when the old SAs 
lifetime are expired. When the old SAs expire without a further SIP message protected by the new SAs, the 
new SAs are taken into use for outbound messages. This completes the SA handling procedure for the 
P-CSCF. 

A failure in the authentication can occur for several reasons. If the SMI was not protected, then no protection shall be 
applied to the failure messages, except the user authentication failure message which shall be protected with the new 
SAs. If SMI was protected, the old SAs shall be used to protect the failure messages. In both cases, after processing the 
failure message, the P-CSCF shall delete the new SAs. 

The P-CSCF shall monitor the expiry time of registrations without an authentication and if necessary increase the 
lifetime of SAs created by the last successful authentication such that it will expire shortly after the registration timer in 
the message. 

The P-CSCF shall delete any SA whose lifetime is exceeded. The P-CSCF shall delete all SAs it holds that are 
associated with a particular IMPI once all the associated IMPUs are de-registered. 
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M.7.5 Rules for security association handling when the UE 
changes IP address 

When a UE changes its IP address, e.g. by using the method described in RFC 3041 [18], then the UE shall delete the 
existing SA's and initiate an unprotected registration procedure using the new IP address as the source IP address in the 
packets carrying the REGISTER messages. 

The text in section 7.5 applies without changes. 



M.8 ISIM 

The text in section 8 applies without changes. 
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